
<!DOCTYPE HTML>
<html lang="zh-hans" >
    <head>
        <meta charset="UTF-8">
        <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
        <title>3.1 Flutter介绍 · Flutter for Harmony教程</title>
        <meta http-equiv="X-UA-Compatible" content="IE=edge" />
        <meta name="description" content="">
        <meta name="generator" content="GitBook 3.2.3">
        <meta name="author" content="坚果派">
        
        
    
    <link rel="stylesheet" href="../gitbook/style.css">

    
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-splitter/splitter.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-tbfed-pagefooter/footer.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-expandable-chapters/expandable-chapters.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-chapter-fold/chapter-fold.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-back-to-top-button/plugin.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-code/plugin.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-pageview-count/plugin.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-search-plus/search.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-emphasize/plugin.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-forkmegithub/plugin.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-highlight/website.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-fontsettings/website.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-theme-lou/lou.css">
                
            
        

    

    
        
        <link rel="stylesheet" href="../styles/website.css">
        
    

        
    
    
    <meta name="HandheldFriendly" content="true"/>
    <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <link rel="apple-touch-icon-precomposed" sizes="152x152" href="../gitbook/images/apple-touch-icon-precomposed-152.png">
    <link rel="shortcut icon" href="../gitbook/images/favicon.ico" type="image/x-icon">

    
    <link rel="next" href="02HarmonyOS与OpenHarmony介绍.html" />
    
    
    <link rel="prev" href="../chapter2/" />
    

    </head>
    <body>
         
<div class="donate-modal modal">
  <div class="modal-header">
    <div>
      <span>
        <img
          id="modal-avatar"
          class="modal-avatar"
          src="http://xkapp-uat.oss-cn-hangzhou.aliyuncs.com/2e7a3f70-80ab-4b50-93ec-a04dfeef949b/avatar-100.png"
        />
      </span>
      <span id="nickname"> breeze </span>
      <p class="modal-close close" onclick="closeDonateModal()">×</p>
    </div>
    <div class="message">
      <div class="tip">
        <i></i>
        <span>随意打赏，但不要超过一顿早餐钱 💕</span>
      </div>
    </div>
  </div>
  <div class="modal-content">
    <div class="modal-pay-way">
      <div id="wxpay" onclick="showDonateImg(0)">
        <input
          type="radio"
          name="pay-way"
          value="wxpay"
          class="zs-type"
          checked="checked"
        />
        <span>
          <img
            id="wxpay-logo"
            src=""
          />
        </span>
      </div>
      <div id="alipay" onclick="showDonateImg(1)">
        <input type="radio" name="pay-way" value="alipay" class="zs-type" />
        <span>
          <img
            id="alipay-logo"
            src=""
          />
        </span>
      </div>
    </div>
    <div class="modal-pay-qrcode">
      <img id="wxpay-code" src="https://luckly007.oss-cn-beijing.aliyuncs.com/img/image-20210922202901895.png" />
      <img
        id="alipay-code"
        src="https://luckly007.oss-cn-beijing.aliyuncs.com/img/image-20210922202843746.png"
        hidden
      />
    </div>
  </div>
</div>
<div class="mask"></div>


<div class="book">
  <div class="header-inner">
    <!-- LOGO -->
    <div class="logo"></div>
    <span class="title"></span>

    <!-- Search -->
    
<div id="book-search-input" role="search">
    <input type="text" placeholder="输入并搜索" />
</div>


    <!-- Nav -->
    <ul class="header-nav">
      <li>
        <a href="https://www.nutpi.net/" target="_blank">坚果派官网</a>
      </li><li>
        <a href="https://www.arkui.club/" target="_blank">ArkUI实战</a>
      </li><li>
        <a href="https://space.bilibili.com/480883651" target="_blank">哔哩哔哩</a>
      </li><li>
        <a href="https://gitcode.com/nutpi" target="_blank">GitCode</a>
      </li>
    </ul>
  </div>

  <div class="book-summary">
    <div class="book-summary-title">文档目录</div>
     
    <nav role="navigation">


<ul class="summary">
    
    

    

    
        
        
    
        <li class="chapter " data-level="1.1" data-path="../">
            
                <a href="../">
            
                    
                    1.前言
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2" data-path="../坚果派介绍.html">
            
                <a href="../坚果派介绍.html">
            
                    
                    2.坚果派介绍
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3" data-path="../chapter2/">
            
                <a href="../chapter2/">
            
                    
                    3.Flutter鸿蒙化
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter active" data-level="1.3.1" data-path="01Flutter介绍.html">
            
                <a href="01Flutter介绍.html">
            
                    
                    3.1 Flutter介绍
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.2" data-path="02HarmonyOS与OpenHarmony介绍.html">
            
                <a href="02HarmonyOS与OpenHarmony介绍.html">
            
                    
                    3.2 背景与原理
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.3" data-path="02功能开发.html">
            
                <a href="02功能开发.html">
            
                    
                    3.3 功能开发
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.4" data-path="03Flutter_Engine编译.html">
            
                <a href="03Flutter_Engine编译.html">
            
                    
                    3.4 Flutter Engine编译
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.5" data-path="03FutterEntry使用.html">
            
                <a href="03FutterEntry使用.html">
            
                    
                    3.5 FutterEntry使用
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.6" data-path="04性能调优.html">
            
                <a href="04性能调优.html">
            
                    
                    3.6 性能调优
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.7" data-path="05OHOS平台适配flutter三方库.html">
            
                <a href="05OHOS平台适配flutter三方库.html">
            
                    
                    3.7 OHOS平台适配flutter三方库
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.8" data-path="06如何使用_Flutter_Channel.html">
            
                <a href="06如何使用_Flutter_Channel.html">
            
                    
                    3.8 如何使用Flutter Channel
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.9" data-path="07开发Flutter静态库.html">
            
                <a href="07开发Flutter静态库.html">
            
                    
                    3.9 开发Flutter静态库
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.10" data-path="FAQ.html">
            
                <a href="FAQ.html">
            
                    
                    3.10 FAQ
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.11" data-path="服务.html">
            
                <a href="服务.html">
            
                    
                    3.11 服务
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.12" data-path="资料整理.html">
            
                <a href="资料整理.html">
            
                    
                    3.12 资料整理
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.13" data-path="../chapter2/2.3Impeller渲染引擎.html">
            
                <a href="../chapter2/2.3Impeller渲染引擎.html">
            
                    
                    3.13 Impeller渲染引擎
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.4" data-path="../chapter3/">
            
                <a href="../chapter3/">
            
                    
                    4.Flutter与Dart介绍
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.4.1" data-path="../chapter3/3.1Flutter介绍.html">
            
                <a href="../chapter3/3.1Flutter介绍.html">
            
                    
                    4.1 Flutter介绍
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.2" data-path="../chapter3/3.2Dart介绍.html">
            
                <a href="../chapter3/3.2Dart介绍.html">
            
                    
                    4.2 Dart介绍
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.5" data-path="../chapter4/">
            
                <a href="../chapter4/">
            
                    
                    5.HarmonyOS/OpenHarmony与ArkTS介绍
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.5.1" data-path="../chapter4/4.1HarmonyOS.html">
            
                <a href="../chapter4/4.1HarmonyOS.html">
            
                    
                    5.1 HarmonyOS
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.5.2" data-path="../chapter4/4.2OpenHarmony.html">
            
                <a href="../chapter4/4.2OpenHarmony.html">
            
                    
                    5.2 OpenHarmony
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.5.3" data-path="../chapter4/4.3HarmonyOSNEXT.html">
            
                <a href="../chapter4/4.3HarmonyOSNEXT.html">
            
                    
                    5.3 HarmonyOS NEXT
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.5.4" data-path="../chapter4/4.4ArkTS语言_.html">
            
                <a href="../chapter4/4.4ArkTS语言_.html">
            
                    
                    5.4 ArkTS语言
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.5.5" data-path="../chapter4/4.5三者的差异.html">
            
                <a href="../chapter4/4.5三者的差异.html">
            
                    
                    5.5 三者的区别与联系
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.5.6" data-path="../chapter4/4.6从开发者视角看_uniapp_与_Flutter_的差异.html">
            
                <a href="../chapter4/4.6从开发者视角看_uniapp_与_Flutter_的差异.html">
            
                    
                    5.6 从开发者视角看uniapp与Flutter的差异
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.6" data-path="../chapter5/">
            
                <a href="../chapter5/">
            
                    
                    6.鸿蒙Flutter开发环境配置
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.6.1" data-path="../chapter5/5.1windows环境配置.html">
            
                <a href="../chapter5/5.1windows环境配置.html">
            
                    
                    6.1 Windows环境配置
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.2" data-path="../chapter5/5.2mac环境配置.md">
            
                <span>
            
                    
                    6.2 Mac环境配置
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.3" data-path="../chapter5/5.2mac环境配置3.32.html">
            
                <a href="../chapter5/5.2mac环境配置3.32.html">
            
                    
                    6.3 Mac环境配置3.32版本
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.4" data-path="../chapter5/5.3使用_FlutterSDK_3.22.1.html">
            
                <a href="../chapter5/5.3使用_FlutterSDK_3.22.1.html">
            
                    
                    6.4 使用FlutterSDK 3.22.1
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.5" data-path="../chapter5/5.4第一个鸿蒙Flutter应用程序.html">
            
                <a href="../chapter5/5.4第一个鸿蒙Flutter应用程序.html">
            
                    
                    6.5 第一个鸿蒙Flutter应用程序
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.6" data-path="../chapter5/5.5鸿蒙Flutter运行到多平台.html">
            
                <a href="../chapter5/5.5鸿蒙Flutter运行到多平台.html">
            
                    
                    6.6 运行到多平台
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.7" data-path="../chapter5/5.5Mac环境Java配置指南.html">
            
                <a href="../chapter5/5.5Mac环境Java配置指南.html">
            
                    
                    6.7 Mac环境Java配置指南
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.8" data-path="../chapter5/5.6使用最新的fluttersdk配置开发环境.html">
            
                <a href="../chapter5/5.6使用最新的fluttersdk配置开发环境.html">
            
                    
                    6.8 使用最新FlutterSDK配置开发环境
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.9" data-path="../chapter5/5.7OpenHarmony设备运行指导.html">
            
                <a href="../chapter5/5.7OpenHarmony设备运行指导.html">
            
                    
                    6.9 OpenHarmony设备运行指导
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.10" data-path="../chapter5/5.8现有项目支持鸿蒙.html">
            
                <a href="../chapter5/5.8现有项目支持鸿蒙.html">
            
                    
                    6.10 现有Flutter项目支持鸿蒙
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.11" data-path="../chapter5/5.9鸿蒙版Flutter仓库变更.html">
            
                <a href="../chapter5/5.9鸿蒙版Flutter仓库变更.html">
            
                    
                    6.11 鸿蒙版Flutter仓库变更
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.12" data-path="../chapter5/5.10真机与模拟器.html">
            
                <a href="../chapter5/5.10真机与模拟器.html">
            
                    
                    6.12 真机与模拟器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.13" data-path="../chapter5/5.11使用fvm.html">
            
                <a href="../chapter5/5.11使用fvm.html">
            
                    
                    6.13 使用FVM管理
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.14" data-path="../chapter5/5.12Ma环境FVM安裝指南.html">
            
                <a href="../chapter5/5.12Ma环境FVM安裝指南.html">
            
                    
                    6.14 Mac环境FVM安装指南
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.15" data-path="../chapter5/5.12使用3.27.4构建鸿蒙应用.html">
            
                <a href="../chapter5/5.12使用3.27.4构建鸿蒙应用.html">
            
                    
                    6.15 使用3.27.4构建鸿蒙应用
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.16" data-path="../chapter5/5.13使用_Flutter_SDK_3.27.4构建HarmonyOS应用.html">
            
                <a href="../chapter5/5.13使用_Flutter_SDK_3.27.4构建HarmonyOS应用.html">
            
                    
                    6.16 使用Flutter SDK 3.27.4构建HarmonyOS应用
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.17" data-path="../chapter5/5.14Flutter-OH版本演进规划和分支策略.html">
            
                <a href="../chapter5/5.14Flutter-OH版本演进规划和分支策略.html">
            
                    
                    6.17 Flutter-OH版本演进规划和分支策略
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.18" data-path="../chapter5/5.15mac环境配置3.22版本.html">
            
                <a href="../chapter5/5.15mac环境配置3.22版本.html">
            
                    
                    6.18 mac环境配置3.22版本
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.7" data-path="../chapter6/">
            
                <a href="../chapter6/">
            
                    
                    7.在鸿蒙应用中添加Flutter页面
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.7.1" data-path="../chapter6/6.1如何使用FlutterPage.html">
            
                <a href="../chapter6/6.1如何使用FlutterPage.html">
            
                    
                    7.1 如何使用FlutterPage
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.7.2" data-path="../chapter6/6.2如何使用混合开发添加跳转_FlutterEntry.html">
            
                <a href="../chapter6/6.2如何使用混合开发添加跳转_FlutterEntry.html">
            
                    
                    7.2 如何使用混合开发添加跳转FlutterEntry
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.7.3" data-path="../chapter6/6.3在鸿蒙应用中添加Flutter页面.html">
            
                <a href="../chapter6/6.3在鸿蒙应用中添加Flutter页面.html">
            
                    
                    7.3 在鸿蒙应用中添加Flutter页面
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.8" data-path="../chapter7/">
            
                <a href="../chapter7/">
            
                    
                    8.Flutter与HarmonyOS混合开发进阶
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.8.1" data-path="../chapter7/7.1如何使用_FlutterPage.md">
            
                <span>
            
                    
                    8.1 如何使用FlutterPage
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.8.2" data-path="../chapter7/7.2如何使用混合开发添加跳转_FlutterEntry.md">
            
                <span>
            
                    
                    8.2 如何使用混合开发添加跳转FlutterEntry
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.8.3" data-path="../chapter7/7.3_harmonyos添加flutter页面跳转时路由的处理.html">
            
                <a href="../chapter7/7.3_harmonyos添加flutter页面跳转时路由的处理.html">
            
                    
                    8.3 harmonyos添加flutter页面跳转时路由的处理
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.8.4" data-path="../chapter7/7.4使用FlutterChannel实现和Flutter和HarmonyOS交互.html">
            
                <a href="../chapter7/7.4使用FlutterChannel实现和Flutter和HarmonyOS交互.html">
            
                    
                    8.4 使用FlutterChannel实现和Flutter和HarmonyOS交互
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.9" data-path="../chapter8/">
            
                <a href="../chapter8/">
            
                    
                    9.在鸿蒙应用中使用Flutter Channel能力
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.9.1" data-path="../chapter8/8.1如何使用混合开发_module.html">
            
                <a href="../chapter8/8.1如何使用混合开发_module.html">
            
                    
                    9.1 如何使用混合开发module
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.9.2" data-path="../chapter8/8.2如何使用混合开发添加跳转_FlutterEntry.html">
            
                <a href="../chapter8/8.2如何使用混合开发添加跳转_FlutterEntry.html">
            
                    
                    9.2 如何使用混合开发添加跳转FlutterEntry
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.9.3" data-path="../chapter8/8.3如何使用lutter和鸿蒙next混合渲染.html">
            
                <a href="../chapter8/8.3如何使用lutter和鸿蒙next混合渲染.html">
            
                    
                    9.3 如何使用Flutter和鸿蒙NEXT混合渲染
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.9.4" data-path="../chapter8/8.4_混合渲染开发实践:以scan_三方库为例.html">
            
                <a href="../chapter8/8.4_混合渲染开发实践:以scan_三方库为例.html">
            
                    
                    9.4 混合渲染开发实践：以fluttertpc_scan三方库为例
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.9.5" data-path="../chapter8/8.5如何使用Flutter与鸿蒙通信_FlutterChannel.html">
            
                <a href="../chapter8/8.5如何使用Flutter与鸿蒙通信_FlutterChannel.html">
            
                    
                    9.5 如何使用Flutter与鸿蒙通信FlutterChannel
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.9.6" data-path="../chapter8/8.7Har包模式引入.html">
            
                <a href="../chapter8/8.7Har包模式引入.html">
            
                    
                    9.6 Har包模式引入
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.9.7" data-path="../chapter8/8.7源码模式引入.html">
            
                <a href="../chapter8/8.7源码模式引入.html">
            
                    
                    9.7 源码模式引入
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.9.8" data-path="../chapter8/8.8初始化Flutter.html">
            
                <a href="../chapter8/8.8初始化Flutter.html">
            
                    
                    9.8 初始化Flutter
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.9.9" data-path="../chapter8/8.9跳转Flutter页面.html">
            
                <a href="../chapter8/8.9跳转Flutter页面.html">
            
                    
                    9.9 跳转Flutter页面
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.10" data-path="../chapter9/">
            
                <a href="../chapter9/">
            
                    
                    10.与原生混合渲染
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.10.1" data-path="../chapter9/9.1flutter鸿蒙化背景.html">
            
                <a href="../chapter9/9.1flutter鸿蒙化背景.html">
            
                    
                    10.1 Flutter鸿蒙化背景
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.10.2" data-path="../chapter9/9.1外接纹理适配.html">
            
                <a href="../chapter9/9.1外接纹理适配.html">
            
                    
                    10.2 Flutter OHOS外接纹理适配简介
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.10.3" data-path="../chapter9/9.2如何使用多引擎_FlutterEngineGroup.html">
            
                <a href="../chapter9/9.2如何使用多引擎_FlutterEngineGroup.html">
            
                    
                    10.3 如何使用多引擎FlutterEngineGroup
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.10.4" data-path="../chapter9/9.3如何使用PlatformView.html">
            
                <a href="../chapter9/9.3如何使用PlatformView.html">
            
                    
                    10.4 如何使用PlatformView
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.10.5" data-path="../chapter9/9.4PlatformView同层渲染方案适配切换指导.html">
            
                <a href="../chapter9/9.4PlatformView同层渲染方案适配切换指导.html">
            
                    
                    10.5 PlatformView同层渲染方案适配切换指导
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.11" data-path="../chapter10/">
            
                <a href="../chapter10/">
            
                    
                    11.开发Flutter静态库
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.11.1" data-path="../chapter10/10.1开发module.html">
            
                <a href="../chapter10/10.1开发module.html">
            
                    
                    11.1开发module
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.11.2" data-path="../chapter10/10.2开发package.html">
            
                <a href="../chapter10/10.2开发package.html">
            
                    
                    11.2开发package
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.11.3" data-path="../chapter10/10.3开发plugin.html">
            
                <a href="../chapter10/10.3开发plugin.html">
            
                    
                    11.3开发plugin
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.11.4" data-path="../chapter10/10.4开发FFI_plugin.html">
            
                <a href="../chapter10/10.4开发FFI_plugin.html">
            
                    
                    11.4开发FFI plugin
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.12" data-path="../chapter11/">
            
                <a href="../chapter11/">
            
                    
                    12.Packages使用指南
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.12.1" data-path="../chapter11/11.1高效使用_Packages指南.html">
            
                <a href="../chapter11/11.1高效使用_Packages指南.html">
            
                    
                    12.1高效使用Packages指南
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.12.2" data-path="../chapter11/11.2发布Packages.html">
            
                <a href="../chapter11/11.2发布Packages.html">
            
                    
                    12.2发布Packages
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.12.3" data-path="../chapter11/11.3使用fvm管理.html">
            
                <a href="../chapter11/11.3使用fvm管理.html">
            
                    
                    12.3使用fvm管理
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.13" data-path="../chapter12/">
            
                <a href="../chapter12/">
            
                    
                    13.鸿蒙适配Flutter三方库
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.13.1" data-path="../chapter12/12.1纯dart库无需迁移.html">
            
                <a href="../chapter12/12.1纯dart库无需迁移.html">
            
                    
                    13.1纯dart库无需迁移
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.2" data-path="../chapter12/12.2坚果派已适配的库.html">
            
                <a href="../chapter12/12.2坚果派已适配的库.html">
            
                    
                    13.2坚果派目前适配三方库进展
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.3" data-path="../chapter12/12.3适配三方库之FlutterToast.html">
            
                <a href="../chapter12/12.3适配三方库之FlutterToast.html">
            
                    
                    13.3适配三方库之FlutterToast
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.4" data-path="../chapter12/12.4适配三方库之udid.html">
            
                <a href="../chapter12/12.4适配三方库之udid.html">
            
                    
                    13.4适配三方库之udid
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.5" data-path="../chapter12/12.5适配torch_light.html">
            
                <a href="../chapter12/12.5适配torch_light.html">
            
                    
                    13.5适配torch_light
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.6" data-path="../chapter12/12.6适配flutter_native_contact_picker.html">
            
                <a href="../chapter12/12.6适配flutter_native_contact_picker.html">
            
                    
                    13.6适配flutter_native_contact_picker
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.7" data-path="../chapter12/12.7适配flutter_timezone.html">
            
                <a href="../chapter12/12.7适配flutter_timezone.html">
            
                    
                    13.7适配flutter_timezone
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.8" data-path="../chapter12/12.8适配flutter_exit_app.html">
            
                <a href="../chapter12/12.8适配flutter_exit_app.html">
            
                    
                    13.8适配flutter_exit_app
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.9" data-path="../chapter12/12.9适配flutter_phone_direct_caller.html">
            
                <a href="../chapter12/12.9适配flutter_phone_direct_caller.html">
            
                    
                    13.9适配flutter_phone_direct_caller
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.10" data-path="../chapter12/12.10适配flutter_app_icon_badge.html">
            
                <a href="../chapter12/12.10适配flutter_app_icon_badge.html">
            
                    
                    13.10适配flutter_app_icon_badge
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.11" data-path="../chapter12/12.10适配screen_capture_event.html">
            
                <a href="../chapter12/12.10适配screen_capture_event.html">
            
                    
                    13.11适配screen_capture_event
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.12" data-path="../chapter12/12.10适配screenshot_callback.html">
            
                <a href="../chapter12/12.10适配screenshot_callback.html">
            
                    
                    13.12适配screenshot_callback
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.13" data-path="../chapter12/12.11适配memory_info.html">
            
                <a href="../chapter12/12.11适配memory_info.html">
            
                    
                    13.13适配memory_info
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.14" data-path="../chapter12/12.11适配screen_brightness.html">
            
                <a href="../chapter12/12.11适配screen_brightness.html">
            
                    
                    13.14适配screen_brightness
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.15" data-path="../chapter12/12.12适配battey_level_plus.html">
            
                <a href="../chapter12/12.12适配battey_level_plus.html">
            
                    
                    13.15适配battey_level_plus
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.16" data-path="../chapter12/12.13适配flutter_badge_plus.html">
            
                <a href="../chapter12/12.13适配flutter_badge_plus.html">
            
                    
                    13.16适配flutter_badge_plus
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.17" data-path="../chapter12/12.14适配flutter_native_contact_picker_plus.html">
            
                <a href="../chapter12/12.14适配flutter_native_contact_picker_plus.html">
            
                    
                    13.17适配flutter_native_contact_picker_plus
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.18" data-path="../chapter12/12.15获取设备随机存取存储器_(RAM">
            
                <span>
            
                    
                    13.18获取设备随机存取存储器 (RAM) 大小
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.19" data-path="../chapter12/12.16适配system_info_plus.html">
            
                <a href="../chapter12/12.16适配system_info_plus.html">
            
                    
                    13.19适配system_info_plus
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.20" data-path="../chapter12/12.17适配app_badge_plus.html">
            
                <a href="../chapter12/12.17适配app_badge_plus.html">
            
                    
                    13.20适配app_badge_plus
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.21" data-path="../chapter12/12.18适配flutter_native_contact_picker_plus.md">
            
                <span>
            
                    
                    13.21适配flutter_native_contact_picker_plus
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.22" data-path="../chapter12/12.19device_info_plus插件适配.html">
            
                <a href="../chapter12/12.19device_info_plus插件适配.html">
            
                    
                    13.22device_info_plus插件适配
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.23" data-path="../chapter12/12.20package_info_plus.html">
            
                <a href="../chapter12/12.20package_info_plus.html">
            
                    
                    13.23package_info_plus
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.24" data-path="../chapter12/12.21NetworkInfo适配.html">
            
                <a href="../chapter12/12.21NetworkInfo适配.html">
            
                    
                    13.24NetworkInfo适配
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.25" data-path="../chapter12/12.22url_luacher适配指南.html">
            
                <a href="../chapter12/12.22url_luacher适配指南.html">
            
                    
                    13.25url_luacher适配指南
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13.26" data-path="../chapter12/di.html">
            
                <a href="../chapter12/di.html">
            
                    
                    13.26依赖注入
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.14" data-path="../chapter13/">
            
                <a href="../chapter13/">
            
                    
                    14.性能优化与调试
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.14.1" data-path="../chapter13/13.1环境配置.html">
            
                <a href="../chapter13/13.1环境配置.html">
            
                    
                    14.1 环境配置
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.14.2" data-path="../chapter13/13.2Flutter_开发鸿蒙应用时三方库引入指南.html">
            
                <a href="../chapter13/13.2Flutter_开发鸿蒙应用时三方库引入指南.html">
            
                    
                    14.2 Flutter开发鸿蒙应用时三方库引入指南
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.14.3" data-path="../chapter13/13.2性能分析定界指南.html">
            
                <a href="../chapter13/13.2性能分析定界指南.html">
            
                    
                    14.3 性能分析定界指南
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.14.4" data-path="../chapter13/13.3梳理线程顺序.html">
            
                <a href="../chapter13/13.3梳理线程顺序.html">
            
                    
                    14.4 性能分析第一步-梳理线程顺序
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.14.5" data-path="../chapter13/13.4滑动响应时延.html">
            
                <a href="../chapter13/13.4滑动响应时延.html">
            
                    
                    14.5 性能分析-滑动响应时延
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.14.6" data-path="../chapter13/13.5帧渲染跟踪.html">
            
                <a href="../chapter13/13.5帧渲染跟踪.html">
            
                    
                    14.6 性能分析-帧渲染跟踪
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.14.7" data-path="../chapter13/13.6如何调试代码.html">
            
                <a href="../chapter13/13.6如何调试代码.html">
            
                    
                    14.7 如何调试代码
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.14.8" data-path="../chapter13/13.7在_Flutter_中实现鸿蒙平台引入_package，其他平台排除.html">
            
                <a href="../chapter13/13.7在_Flutter_中实现鸿蒙平台引入_package，其他平台排除.html">
            
                    
                    14.8 在Flutter中实现鸿蒙平台引入package，其他平台排除
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.14.9" data-path="../chapter13/运行.html">
            
                <a href="../chapter13/运行.html">
            
                    
                    14.9 运行
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.15" data-path="../chapter14/">
            
                <a href="../chapter14/">
            
                    
                    15.迁移实战
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.15.1" data-path="../chapter14/14.1拨打电话.html">
            
                <a href="../chapter14/14.1拨打电话.html">
            
                    
                    15.1 拨打电话
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.15.2" data-path="../chapter14/14.2使用url_launcher.html">
            
                <a href="../chapter14/14.2使用url_launcher.html">
            
                    
                    15.2 使用url_launcher
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.15.3" data-path="../chapter14/14.3flutter开发鸿蒙PC应用.html">
            
                <a href="../chapter14/14.3flutter开发鸿蒙PC应用.html">
            
                    
                    15.3 flutter开发鸿蒙PC应用
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.15.4" data-path="../chapter14/14.4探索适用于鸿蒙原生应用的跨平台开发框架.html">
            
                <a href="../chapter14/14.4探索适用于鸿蒙原生应用的跨平台开发框架.html">
            
                    
                    15.4 探索适用于鸿蒙原生应用的跨平台开发框架
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.15.5" data-path="../chapter14/14.5保存图片.html">
            
                <a href="../chapter14/14.5保存图片.html">
            
                    
                    15.5 保存图片
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.15.6" data-path="../chapter14/14.6使用url.html">
            
                <a href="../chapter14/14.6使用url.html">
            
                    
                    15.6 使用url
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.15.7" data-path="../chapter14/今日时鉴.html">
            
                <a href="../chapter14/今日时鉴.html">
            
                    
                    15.7 今日时鉴
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.16" data-path="../chapter15/">
            
                <a href="../chapter15/">
            
                    
                    16.上架审核
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.16.1" data-path="../chapter15/15.1应用上架流程.html">
            
                <a href="../chapter15/15.1应用上架流程.html">
            
                    
                    16.1应用上架流程
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.16.2" data-path="../chapter15/15.2审核注意事项.html">
            
                <a href="../chapter15/15.2审核注意事项.html">
            
                    
                    16.2审核注意事项
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.17" data-path="../chapter16/">
            
                <a href="../chapter16/">
            
                    
                    17.FAQ
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.17.1" data-path="../chapter16/16.1ohos应用编译相关问题.html">
            
                <a href="../chapter16/16.1ohos应用编译相关问题.html">
            
                    
                    17.1 ohos应用编译相关问题
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.17.2" data-path="../chapter16/16.2原有项目迁移鸿蒙.html">
            
                <a href="../chapter16/16.2原有项目迁移鸿蒙.html">
            
                    
                    17.2 原有项目迁移鸿蒙
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.17.3" data-path="../chapter16/16.3权限相关.html">
            
                <a href="../chapter16/16.3权限相关.html">
            
                    
                    17.3 权限相关
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.17.4" data-path="../chapter16/16.4Flutter_3.22.0-ohos_0.1.0_Release发布.html">
            
                <a href="../chapter16/16.4Flutter_3.22.0-ohos_0.1.0_Release发布.html">
            
                    
                    17.4 Flutter 3.22.0-ohos 0.1.0 Release发布
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.17.5" data-path="../chapter16/16.5环境相关问题.html">
            
                <a href="../chapter16/16.5环境相关问题.html">
            
                    
                    17.5 环境相关问题
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.17.6" data-path="../chapter16/16.6ohos代码开发相关问题.html">
            
                <a href="../chapter16/16.6ohos代码开发相关问题.html">
            
                    
                    17.6 ohos代码开发相关问题
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.17.7" data-path="../chapter16/16.7解析flutter相关的cppcrash堆栈.html">
            
                <a href="../chapter16/16.7解析flutter相关的cppcrash堆栈.html">
            
                    
                    17.7 解析flutter相关的cppcrash堆栈
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.17.8" data-path="../chapter16/16.8ohos引擎产物编译相关问题.html">
            
                <a href="../chapter16/16.8ohos引擎产物编译相关问题.html">
            
                    
                    17.8 ohos引擎产物编译相关问题
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.17.9" data-path="../chapter16/ffi.html">
            
                <a href="../chapter16/ffi.html">
            
                    
                    17.9 FFI
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.17.10" data-path="../chapter16/三方库相关.html">
            
                <a href="../chapter16/三方库相关.html">
            
                    
                    17.10 三方库相关
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.18" data-path="../chapter17/">
            
                <a href="../chapter17/">
            
                    
                    18.阅读更多
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.18.1" data-path="../chapter17/17.1版本.html">
            
                <a href="../chapter17/17.1版本.html">
            
                    
                    18.1 适配HarmonyOS Next API16的鸿蒙版Flutter 3.22.0版本发布
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.18.2" data-path="../chapter17/17.2平台判断与问题处理指南.html">
            
                <a href="../chapter17/17.2平台判断与问题处理指南.html">
            
                    
                    18.2 平台判断与问题处理指南
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.18.3" data-path="../chapter17/17.3鸿蒙版Flutter_3.22.0版本正式发布(1.0Release">
            
                <span>
            
                    
                    18.3 鸿蒙版Flutter 3.22.0版本正式发布(1.0Release)
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.18.4" data-path="../chapter17/17.4优化_ohos_构建过程.html">
            
                <a href="../chapter17/17.4优化_ohos_构建过程.html">
            
                    
                    18.4 优化ohos构建过程
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.18.5" data-path="../chapter17/17.5新增use-application-binary命令.html">
            
                <a href="../chapter17/17.5新增use-application-binary命令.html">
            
                    
                    18.5 新增use-application-binary命令
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.18.6" data-path="../chapter17/17.6Flutter_3.22.0-ohos_1.0.1_Release发布.md">
            
                <span>
            
                    
                    18.6 Flutter 3.22.0-ohos 1.0.1 Release发布
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.18.7" data-path="../chapter17/17.7关于插件参数传递.html">
            
                <a href="../chapter17/17.7关于插件参数传递.html">
            
                    
                    18.7 关于插件参数传递
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.18.8" data-path="../chapter17/17.8关于鸿蒙版Flutter的_context_.html">
            
                <a href="../chapter17/17.8关于鸿蒙版Flutter的_context_.html">
            
                    
                    18.8 关于鸿蒙版Flutter的context
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.18.9" data-path="../chapter17/5.1API_18正式发布.html">
            
                <a href="../chapter17/5.1API_18正式发布.html">
            
                    
                    18.9 5.1API 18正式发布
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.18.10" data-path="../chapter17/5.1完整.html">
            
                <a href="../chapter17/5.1完整.html">
            
                    
                    18.10 5.1完整
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.19" data-path="../chapter18/">
            
                <a href="../chapter18/">
            
                    
                    19.多设备能力
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.19.1" data-path="../chapter18/18.1多设备自适应布局.html">
            
                <a href="../chapter18/18.1多设备自适应布局.html">
            
                    
                    19.1 自适应布局
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.19.2" data-path="../chapter18/18.2多设备响应式布局.html">
            
                <a href="../chapter18/18.2多设备响应式布局.html">
            
                    
                    19.2 响应式布局
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.19.3" data-path="../chapter18/18.3多设备典型布局场景.html">
            
                <a href="../chapter18/18.3多设备典型布局场景.html">
            
                    
                    19.3 典型布局场景
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.19.4" data-path="../chapter18/18.4交互归一能力.html">
            
                <a href="../chapter18/18.4交互归一能力.html">
            
                    
                    19.4 交互归一能力
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.20" data-path="../chapter19/README.md">
            
                <span>
            
                    
                    20.关于未来
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.21" data-path="../chapter20/">
            
                <a href="../chapter20/">
            
                    
                    21.版本更新
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.21.1" data-path="../chapter20/20.1鸿蒙版Flutter_3.22.0版本正式发布(1.0Release">
            
                <span>
            
                    
                    21.1 鸿蒙版Flutter 3.22.0版本正式发布(1.0Release)
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.21.2" data-path="../chapter20/20.2Flutter_3.22.0-ohos_1.0.1_Release发布.html">
            
                <a href="../chapter20/20.2Flutter_3.22.0-ohos_1.0.1_Release发布.html">
            
                    
                    21.2 Flutter 3.22.0-ohos 1.0.1 Release发布
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.21.3" data-path="../chapter20/20.3发布新版本.html">
            
                <a href="../chapter20/20.3发布新版本.html">
            
                    
                    21.3 发布新版本
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.21.4" data-path="../chapter20/20.4Flutter3.22.0-ohos-1.0.4发布.html">
            
                <a href="../chapter20/20.4Flutter3.22.0-ohos-1.0.4发布.html">
            
                    
                    21.4 Flutter3.22.0-ohos-1.0.4发布
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.21.5" data-path="../chapter20/20.5如何升级插件升级最新的鸿蒙版_flutter.html">
            
                <a href="../chapter20/20.5如何升级插件升级最新的鸿蒙版_flutter.html">
            
                    
                    21.5 如何升级插件升级最新的鸿蒙版flutter
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.21.6" data-path="../chapter20/20.6各版本的鸿蒙版flutter如何获取.html">
            
                <a href="../chapter20/20.6各版本的鸿蒙版flutter如何获取.html">
            
                    
                    21.6 各版本的鸿蒙版flutter如何获取
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.21.7" data-path="../chapter20/20.7新版本发布.html">
            
                <a href="../chapter20/20.7新版本发布.html">
            
                    
                    21.7 新版本发布
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.22" data-path="../致谢.html">
            
                <a href="../致谢.html">
            
                    
                    致谢
            
                </a>
            

            
        </li>
    

    

    <li class="divider"></li>

    <li>
        <a href="https://www.gitbook.com" target="blank" class="gitbook-link">
            本书使用 GitBook 发布
        </a>
    </li>
</ul>

</nav>
     
  </div>

  <!-- Content nav -->
  <div class="book-anchor">
    <div class="book-anchor-title"></div>

    <div class="book-anchor-body"></div>
  </div>

  <div class="book-body">
    
    <div class="body-inner">
       

<div class="book-header" role="navigation">
    

    <!-- Title -->
    <h1>
        <i class="fa fa-circle-o-notch fa-spin"></i>
        <a href=".." >3.1 Flutter介绍</a>
    </h1>
</div>



      <div class="page-wrapper" tabindex="-1" role="main">
        <div class="page-inner">
          
<div class="search-plus" id="book-search-results">
    <div class="search-noresults">
    
          <section class="normal markdown-section">
             <h1 id="flutter-&#x6846;&#x67B6;&#x4ECB;&#x7ECD;">Flutter &#x6846;&#x67B6;&#x4ECB;&#x7ECD;</h1>
<h2 id="&#x4EC0;&#x4E48;&#x662F;flutter&#xFF1F;">&#x4EC0;&#x4E48;&#x662F;Flutter&#xFF1F;</h2>
<p>Flutter&#x662F;&#x8C37;&#x6B4C;&#x5F00;&#x53D1;&#x7684;&#x9AD8;&#x6027;&#x80FD;&#x3001;&#x8DE8;&#x7AEF;UI&#x6846;&#x67B6;&#xFF0C;&#x53EF;&#x4EE5;&#x901A;&#x8FC7;&#x4E00;&#x5957;&#x4EE3;&#x7801;&#x652F;&#x6301;iOS&#x3001;Android&#x3001;Windows&#x3001;macOS&#x3001;Linux&#x7B49;&#x591A;&#x4E2A;&#x5E73;&#x53F0;&#xFF0C;&#x4E14;&#x80FD;&#x8FBE;&#x5230;&#x539F;&#x751F;&#x6027;&#x80FD;&#x3002;Flutter&#x4E5F;&#x53EF;&#x4EE5;&#x4E0E;&#x5E73;&#x53F0;&#x539F;&#x751F;&#x4EE3;&#x7801;&#x8FDB;&#x884C;&#x6DF7;&#x5408;&#x5F00;&#x53D1;&#x3002;&#x5728;&#x5168;&#x4E16;&#x754C;&#xFF0C;Flutter&#x6B63;&#x5728;&#x88AB;&#x8D8A;&#x6765;&#x8D8A;&#x591A;&#x7684;&#x5F00;&#x53D1;&#x8005;&#x548C;&#x7EC4;&#x7EC7;&#x4F7F;&#x7528;&#xFF0C;&#x5E76;&#x4E14;Flutter&#x662F;&#x5B8C;&#x5168;&#x514D;&#x8D39;&#x3001;&#x5F00;&#x6E90;&#x7684;&#x3002;</p>
<h3 id="&#x1F3AF;-&#x6838;&#x5FC3;&#x7279;&#x70B9;">&#x1F3AF; &#x6838;&#x5FC3;&#x7279;&#x70B9;</h3>
<table>
<thead>
<tr>
<th>&#x7279;&#x70B9;</th>
<th>&#x63CF;&#x8FF0;</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>&#x8DE8;&#x5E73;&#x53F0;</strong></td>
<td>&#x4E00;&#x5957;&#x4EE3;&#x7801;&#xFF0C;&#x591A;&#x5E73;&#x53F0;&#x8FD0;&#x884C;</td>
</tr>
<tr>
<td><strong>&#x9AD8;&#x6027;&#x80FD;</strong></td>
<td>&#x63A5;&#x8FD1;&#x539F;&#x751F;&#x5E94;&#x7528;&#x7684;&#x6027;&#x80FD;&#x8868;&#x73B0;</td>
</tr>
<tr>
<td><strong>&#x70ED;&#x91CD;&#x8F7D;</strong></td>
<td>&#x5FEB;&#x901F;&#x5F00;&#x53D1;&#x8C03;&#x8BD5;&#xFF0C;&#x5B9E;&#x65F6;&#x9884;&#x89C8;&#x6548;&#x679C;</td>
</tr>
<tr>
<td><strong>&#x4E30;&#x5BCC;&#x7EC4;&#x4EF6;</strong></td>
<td>&#x63D0;&#x4F9B;&#x4E30;&#x5BCC;&#x7684;UI&#x7EC4;&#x4EF6;&#x5E93;</td>
</tr>
<tr>
<td><strong>&#x5F00;&#x6E90;&#x514D;&#x8D39;</strong></td>
<td>&#x5B8C;&#x5168;&#x5F00;&#x6E90;&#xFF0C;&#x793E;&#x533A;&#x6D3B;&#x8DC3;</td>
</tr>
</tbody>
</table>
<h3 id="&#x1F4DA;-&#x6280;&#x672F;&#x6808;&#x5BF9;&#x6BD4;">&#x1F4DA; &#x6280;&#x672F;&#x6808;&#x5BF9;&#x6BD4;</h3>
<table>
<thead>
<tr>
<th>&#x5E73;&#x53F0;</th>
<th>&#x6846;&#x67B6;</th>
<th>&#x5F00;&#x53D1;&#x8BED;&#x8A00;</th>
<th>&#x8BF4;&#x660E;</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Flutter</strong></td>
<td>Flutter</td>
<td>Dart</td>
<td>&#x8DE8;&#x5E73;&#x53F0;UI&#x6846;&#x67B6;</td>
</tr>
<tr>
<td><strong>&#x9E3F;&#x8499;&#x539F;&#x751F;</strong></td>
<td>ArkUI</td>
<td>ArkTS</td>
<td>&#x9E3F;&#x8499;&#x539F;&#x751F;&#x5F00;&#x53D1;</td>
</tr>
<tr>
<td><strong>Android</strong></td>
<td>Android SDK</td>
<td>Java/Kotlin</td>
<td>Android&#x539F;&#x751F;&#x5F00;&#x53D1;</td>
</tr>
<tr>
<td><strong>iOS</strong></td>
<td>UIKit/SwiftUI</td>
<td>Swift/Objective-C</td>
<td>iOS&#x539F;&#x751F;&#x5F00;&#x53D1;</td>
</tr>
</tbody>
</table>
<blockquote>
<p>&#x1F4A1; <strong>&#x91CD;&#x8981;&#x6982;&#x5FF5;</strong>&#xFF1A;Flutter&#x662F;&#x6846;&#x67B6;&#xFF0C;&#x5F00;&#x53D1;&#x8BED;&#x8A00;&#x662F;Dart&#xFF0C;&#x7C7B;&#x4F3C;&#x4E8E;&#x9E3F;&#x8499;&#x539F;&#x751F;&#x5E94;&#x7528;&#x5F00;&#x53D1;&#x4E2D;&#xFF0C;ArkUI&#x662F;&#x6846;&#x67B6;&#xFF0C;ArkTS&#x662F;&#x5F00;&#x53D1;&#x8BED;&#x8A00;&#x3002;</p>
</blockquote>
<h2 id="flutter&#x67B6;&#x6784;">Flutter&#x67B6;&#x6784;</h2>
<p>Flutter&#x88AB;&#x8BBE;&#x8BA1;&#x4E3A;&#x4E00;&#x4E2A;&#x53EF;&#x6269;&#x5C55;&#x7684;&#x5206;&#x5C42;&#x7CFB;&#x7EDF;&#x3002;&#x5B83;&#x53EF;&#x4EE5;&#x88AB;&#x770B;&#x4F5C;&#x662F;&#x5404;&#x4E2A;&#x72EC;&#x7ACB;&#x7EC4;&#x4EF6;&#x7684;&#x7CFB;&#x5217;&#x5408;&#x96C6;&#xFF0C;&#x4E0A;&#x5C42;&#x7EC4;&#x4EF6;&#x5404;&#x81EA;&#x4F9D;&#x8D56;&#x4E0B;&#x5C42;&#x7EC4;&#x4EF6;&#x3002;&#x7EC4;&#x4EF6;&#x65E0;&#x6CD5;&#x8D8A;&#x6743;&#x8BBF;&#x95EE;&#x66F4;&#x5E95;&#x5C42;&#x7684;&#x5185;&#x5BB9;&#xFF0C;&#x5E76;&#x4E14;&#x6846;&#x67B6;&#x5C42;&#x4E2D;&#x7684;&#x5404;&#x4E2A;&#x90E8;&#x5206;&#x90FD;&#x662F;&#x53EF;&#x9009;&#x4E14;&#x53EF;&#x66FF;&#x4EE3;&#x7684;&#x3002;&#x6BCF;&#x4E00;&#x5757;&#x90FD;&#x5404;&#x53F8;&#x5176;&#x804C;&#xFF0C;&#x8D1F;&#x8D23;&#x81EA;&#x5DF1;&#x7684;&#x6A21;&#x5757;&#x3002;</p>
<p><img src="https://luckly007.oss-cn-beijing.aliyuncs.com/uPic/archdiagram.png" alt="Flutter&#x67B6;&#x6784;&#x56FE;"></p>
<h3 id="&#x1F3D7;&#xFE0F;-&#x67B6;&#x6784;&#x5C42;&#x6B21;">&#x1F3D7;&#xFE0F; &#x67B6;&#x6784;&#x5C42;&#x6B21;</h3>
<table>
<thead>
<tr>
<th>&#x5C42;&#x6B21;</th>
<th>&#x7EC4;&#x4EF6;</th>
<th>&#x804C;&#x8D23;</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>&#x5E94;&#x7528;&#x5C42;</strong></td>
<td>Material/Cupertino</td>
<td>&#x63D0;&#x4F9B;&#x5E73;&#x53F0;&#x7279;&#x5B9A;&#x7684;UI&#x7EC4;&#x4EF6;</td>
</tr>
<tr>
<td><strong>&#x6846;&#x67B6;&#x5C42;</strong></td>
<td>Widgets/Rendering</td>
<td>&#x5904;&#x7406;UI&#x6E32;&#x67D3;&#x548C;&#x5E03;&#x5C40;</td>
</tr>
<tr>
<td><strong>&#x5F15;&#x64CE;&#x5C42;</strong></td>
<td>Flutter Engine</td>
<td>&#x63D0;&#x4F9B;&#x5E95;&#x5C42;&#x6E32;&#x67D3;&#x548C;&#x5E73;&#x53F0;&#x4EA4;&#x4E92;</td>
</tr>
<tr>
<td><strong>&#x5D4C;&#x5165;&#x5C42;</strong></td>
<td>Platform Embedder</td>
<td>&#x4E0E;&#x64CD;&#x4F5C;&#x7CFB;&#x7EDF;&#x4EA4;&#x4E92;</td>
</tr>
</tbody>
</table>
<h3 id="&#x1F527;-&#x6838;&#x5FC3;&#x7EC4;&#x4EF6;">&#x1F527; &#x6838;&#x5FC3;&#x7EC4;&#x4EF6;</h3>
<ul>
<li><strong>Widget</strong>&#xFF1A;Flutter&#x4E2D;&#x4E00;&#x5207;&#x7686;Widget&#xFF0C;&#x662F;UI&#x6784;&#x5EFA;&#x7684;&#x57FA;&#x672C;&#x5355;&#x5143;</li>
<li><strong>Element</strong>&#xFF1A;Widget&#x7684;&#x5B9E;&#x4F8B;&#x5316;&#x5BF9;&#x8C61;&#xFF0C;&#x8D1F;&#x8D23;&#x7BA1;&#x7406;Widget&#x6811;</li>
<li><strong>RenderObject</strong>&#xFF1A;&#x8D1F;&#x8D23;&#x5B9E;&#x9645;&#x7684;&#x5E03;&#x5C40;&#x548C;&#x7ED8;&#x5236;</li>
<li><strong>Engine</strong>&#xFF1A;&#x5E95;&#x5C42;&#x6E32;&#x67D3;&#x5F15;&#x64CE;&#xFF0C;&#x5904;&#x7406;&#x56FE;&#x5F62;&#x7ED8;&#x5236;&#x548C;&#x5E73;&#x53F0;&#x4EA4;&#x4E92;</li>
</ul>
<h2 id="&#x9E3F;&#x8499;&#x7248;flutter&#x73AF;&#x5883;&#x642D;&#x5EFA;">&#x9E3F;&#x8499;&#x7248;Flutter&#x73AF;&#x5883;&#x642D;&#x5EFA;</h2>
<h3 id="&#x1F4CB;-&#x73AF;&#x5883;&#x8981;&#x6C42;">&#x1F4CB; &#x73AF;&#x5883;&#x8981;&#x6C42;</h3>
<p>&#x9E3F;&#x8499;&#x7248;Flutter&#x9879;&#x76EE;&#x662F;&#x6211;&#x4EEC;&#x6574;&#x4E2A;&#x5DE5;&#x7A0B;&#x7684;&#x6838;&#x5FC3;&#xFF0C;&#x4F46;&#x662F;&#x5F88;&#x591A;&#x4EBA;&#x90FD;&#x5012;&#x5728;&#x4E86;&#x7B2C;&#x4E00;&#x6B65;&#xFF0C;&#x5176;&#x539F;&#x56E0;&#x5C31;&#x662F;&#x2014;&#x2014;<strong>&#x9700;&#x8981;&#x4F7F;&#x7528;Dev&#x5206;&#x652F;</strong>&#xFF01;&#xFF01;&#xFF01;</p>
<blockquote>
<p>&#x1F517; <strong>&#x9879;&#x76EE;&#x5730;&#x5740;</strong>&#xFF1A;<a href="https://gitee.com/openharmony-tpc/flutter_flutter/tree/dev/" target="_blank">https://gitee.com/openharmony-tpc/flutter_flutter/tree/dev/</a></p>
</blockquote>
<h3 id="&#x26A0;&#xFE0F;-&#x91CD;&#x8981;&#x6CE8;&#x610F;&#x4E8B;&#x9879;">&#x26A0;&#xFE0F; &#x91CD;&#x8981;&#x6CE8;&#x610F;&#x4E8B;&#x9879;</h3>
<table>
<thead>
<tr>
<th>&#x9879;&#x76EE;</th>
<th>&#x8981;&#x6C42;</th>
<th>&#x8BF4;&#x660E;</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>&#x64CD;&#x4F5C;&#x7CFB;&#x7EDF;</strong></td>
<td>Linux&#x3001;Mac&#x3001;Windows</td>
<td>&#x76EE;&#x524D;&#x652F;&#x6301;&#x8FD9;&#x4E09;&#x4E2A;&#x5E73;&#x53F0;</td>
</tr>
<tr>
<td><strong>&#x7CFB;&#x7EDF;&#x67B6;&#x6784;</strong></td>
<td>x86_64 &#x6216; arm64</td>
<td>Mac&#x7CFB;&#x7EDF;&#x4F7F;&#x7528;<code>uname -m</code>&#x67E5;&#x770B;&#x67B6;&#x6784;</td>
</tr>
<tr>
<td><strong>&#x5F00;&#x53D1;&#x5957;&#x4EF6;</strong></td>
<td>&#x6700;&#x65B0;&#x7248;&#x672C;</td>
<td>&#x4F7F;&#x7528;&#x5B98;&#x65B9;&#x4E0B;&#x8F7D;&#x5730;&#x5740;&#xFF0C;&#x6027;&#x80FD;&#x66F4;&#x4F73;</td>
</tr>
<tr>
<td><strong>&#x5206;&#x652F;&#x9009;&#x62E9;</strong></td>
<td>dev&#x5206;&#x652F;</td>
<td>&#x5FC5;&#x987B;&#x4F7F;&#x7528;dev&#x5206;&#x652F;&#xFF0C;master&#x5206;&#x652F;&#x4E0D;&#x652F;&#x6301;</td>
</tr>
</tbody>
</table>
<h3 id="&#x1F50D;-&#x7CFB;&#x7EDF;&#x67B6;&#x6784;&#x68C0;&#x67E5;">&#x1F50D; &#x7CFB;&#x7EDF;&#x67B6;&#x6784;&#x68C0;&#x67E5;</h3>
<p>&#x5728;Mac&#x7CFB;&#x7EDF;&#x7EC8;&#x7AEF;&#x8F93;&#x5165;&#x4EE5;&#x4E0B;&#x547D;&#x4EE4;&#x5224;&#x65AD;&#x7CFB;&#x7EDF;&#x67B6;&#x6784;&#xFF1A;</p>
<pre><code class="lang-bash">uname -m
</code></pre>
<ul>
<li>&#x5982;&#x679C;&#x8F93;&#x51FA;&#x7ED3;&#x679C;&#x662F; <code>x86_64</code>&#xFF0C;&#x5219;&#x8868;&#x793A;&#x4F60;&#x7684;&#x7CFB;&#x7EDF;&#x662F;x86-64&#x67B6;&#x6784;</li>
<li>&#x5982;&#x679C;&#x8F93;&#x51FA;&#x7ED3;&#x679C;&#x662F; <code>arm64</code>&#xFF0C;&#x5219;&#x8868;&#x793A;&#x4F60;&#x7684;&#x7CFB;&#x7EDF;&#x662F;arm64&#x67B6;&#x6784;</li>
</ul>
<h3 id="&#x1F4E6;-&#x5F00;&#x53D1;&#x5957;&#x4EF6;&#x4E0B;&#x8F7D;">&#x1F4E6; &#x5F00;&#x53D1;&#x5957;&#x4EF6;&#x4E0B;&#x8F7D;</h3>
<p>&#x9E3F;&#x8499;&#x5F00;&#x53D1;&#x5957;&#x4EF6;&#x5B98;&#x65B9;&#x4E0B;&#x8F7D;&#x5730;&#x5740;&#xFF1A;<a href="https://developer.huawei.com/consumer/cn/download/" target="_blank">https://developer.huawei.com/consumer/cn/download/</a></p>
<blockquote>
<p>&#x1F4A1; <strong>&#x5EFA;&#x8BAE;</strong>&#xFF1A;&#x4E0B;&#x8F7D;&#x6700;&#x65B0;&#x5957;&#x4EF6;&#xFF0C;&#x66F4;&#x52A0;&#x7A33;&#x5B9A;&#xFF0C;&#x6027;&#x80FD;&#x66F4;&#x4F73;&#xFF0C;&#x4E14;&#x9E3F;&#x8499;Flutter&#x9700;&#x8981;&#x4F9D;&#x8D56;&#x6700;&#x65B0;&#x5957;&#x4EF6;&#x7F16;&#x8BD1;</p>
</blockquote>
<h3 id="&#x1F4E5;-&#x4E0B;&#x8F7D;&#x9E3F;&#x8499;&#x7248;flutter">&#x1F4E5; &#x4E0B;&#x8F7D;&#x9E3F;&#x8499;&#x7248;Flutter</h3>
<p><strong>&#x9879;&#x76EE;&#x5730;&#x5740;</strong>&#xFF1A;<a href="https://gitee.com/openharmony-tpc/flutter_flutter" target="_blank">https://gitee.com/openharmony-tpc/flutter_flutter</a></p>
<p>&#x901A;&#x8FC7;&#x4EE3;&#x7801;&#x5DE5;&#x5177;&#x4E0B;&#x8F7D;&#x4ED3;&#x5E93;&#x4EE3;&#x7801;&#x5E76;&#x6307;&#x5B9A;dev&#x6216;master&#x5206;&#x652F;&#xFF0C;dev&#x4E0D;&#x65AD;&#x5728;&#x66F4;&#x65B0;&#x76F8;&#x6BD4;master&#x62E5;&#x6709;&#x66F4;&#x591A;&#x529F;&#x80FD;&#xFF1A;</p>
<pre><code class="lang-bash"><span class="hljs-comment"># &#x514B;&#x9686;&#x9879;&#x76EE;</span>
git <span class="hljs-built_in">clone</span> https://gitee.com/openharmony-tpc/flutter_flutter.git

<span class="hljs-comment"># &#x5207;&#x6362;&#x5230;dev&#x5206;&#x652F;</span>
git checkout -b dev origin/dev
</code></pre>
<blockquote>
<p>&#x26A0;&#xFE0F; <strong>&#x91CD;&#x8981;</strong>&#xFF1A;&#x5FC5;&#x987B;&#x4F7F;&#x7528;dev&#x5206;&#x652F;&#xFF0C;master&#x5206;&#x652F;&#x4E0D;&#x652F;&#x6301;&#x9E3F;&#x8499;&#x5E73;&#x53F0;</p>
</blockquote>
<h3 id="&#x2699;&#xFE0F;-&#x73AF;&#x5883;&#x53D8;&#x91CF;&#x914D;&#x7F6E;">&#x2699;&#xFE0F; &#x73AF;&#x5883;&#x53D8;&#x91CF;&#x914D;&#x7F6E;</h3>
<h4 id="1-&#x7F16;&#x8F91;&#x914D;&#x7F6E;&#x6587;&#x4EF6;">1. &#x7F16;&#x8F91;&#x914D;&#x7F6E;&#x6587;&#x4EF6;</h4>
<pre><code class="lang-bash"><span class="hljs-comment"># &#x6253;&#x5F00;&#x914D;&#x7F6E;&#x6587;&#x4EF6;</span>
open ~/.bash_profile
</code></pre>
<h4 id="2-&#x6DFB;&#x52A0;&#x73AF;&#x5883;&#x53D8;&#x91CF;">2. &#x6DFB;&#x52A0;&#x73AF;&#x5883;&#x53D8;&#x91CF;</h4>
<p>&#x5728;&#x914D;&#x7F6E;&#x6587;&#x4EF6;&#x4E2D;&#x6DFB;&#x52A0;&#x4EE5;&#x4E0B;&#x5185;&#x5BB9;&#xFF1A;</p>
<pre><code class="lang-bash"><span class="hljs-comment"># DevEco Studio&#x914D;&#x7F6E;</span>
<span class="hljs-built_in">export</span> TOOL_HOME=/Applications/DevEco-Studio.app/Contents 
<span class="hljs-built_in">export</span> DEVECO_SDK_HOME=<span class="hljs-variable">$TOOL_HOME</span>/sdk 

<span class="hljs-comment"># &#x5DE5;&#x5177;&#x8DEF;&#x5F84;&#x914D;&#x7F6E;</span>
<span class="hljs-built_in">export</span> PATH=<span class="hljs-variable">$TOOL_HOME</span>/tools/ohpm/bin:<span class="hljs-variable">$PATH</span> 
<span class="hljs-built_in">export</span> PATH=<span class="hljs-variable">$TOOL_HOME</span>/tools/hvigor/bin:<span class="hljs-variable">$PATH</span> 
<span class="hljs-built_in">export</span> PATH=<span class="hljs-variable">$TOOL_HOME</span>/tools/node/bin:<span class="hljs-variable">$PATH</span> 

<span class="hljs-comment"># Flutter&#x8DEF;&#x5F84;&#x914D;&#x7F6E;&#xFF08;&#x8BF7;&#x6839;&#x636E;&#x5B9E;&#x9645;&#x5B89;&#x88C5;&#x8DEF;&#x5F84;&#x4FEE;&#x6539;&#xFF09;</span>
<span class="hljs-built_in">export</span> PATH=/Users/jianguo/huawei/flutter_flutter/bin:<span class="hljs-variable">$PATH</span>

<span class="hljs-comment"># &#x56FD;&#x5185;&#x955C;&#x50CF;&#x914D;&#x7F6E;</span>
<span class="hljs-built_in">export</span> PUB_HOSTED_URL=https://pub.flutter-io.cn
<span class="hljs-built_in">export</span> FLUTTER_STORAGE_BASE_URL=https://storage.flutter-io.cn
</code></pre>
<h4 id="3-&#x5237;&#x65B0;&#x914D;&#x7F6E;">3. &#x5237;&#x65B0;&#x914D;&#x7F6E;</h4>
<pre><code class="lang-bash"><span class="hljs-comment"># &#x5237;&#x65B0;&#x73AF;&#x5883;&#x53D8;&#x91CF;</span>
<span class="hljs-built_in">source</span> ~/.bash_profile
</code></pre>
<blockquote>
<p>&#x26A0;&#xFE0F; <strong>&#x6CE8;&#x610F;</strong>&#xFF1A;&#x8BF7;&#x6839;&#x636E;&#x4F60;&#x7684;&#x5B9E;&#x9645;DevEco-Studio&#x5B89;&#x88C5;&#x76EE;&#x5F55;&#x4FEE;&#x6539;<code>TOOL_HOME</code>&#x8DEF;&#x5F84;&#xFF0C;&#x56E0;&#x4E3A;&#x4E0D;&#x540C;&#x7528;&#x6237;&#x53EF;&#x80FD;&#x6709;&#x4E0D;&#x540C;&#x7684;&#x5B89;&#x88C5;&#x76EE;&#x5F55;&#x3002;</p>
</blockquote>
<h4 id="4-&#x9A8C;&#x8BC1;&#x914D;&#x7F6E;">4. &#x9A8C;&#x8BC1;&#x914D;&#x7F6E;</h4>
<p>&#x914D;&#x7F6E;&#x5B8C;&#x6210;&#x540E;&#xFF0C;&#x8FD0;&#x884C;&#x4EE5;&#x4E0B;&#x547D;&#x4EE4;&#x68C0;&#x6D4B;&#x73AF;&#x5883;&#x53D8;&#x91CF;&#x662F;&#x5426;&#x914D;&#x7F6E;&#x6B63;&#x786E;&#xFF1A;</p>
<pre><code class="lang-bash">flutter doctor -v
</code></pre>
<p><img src="https://luckly007.oss-cn-beijing.aliyuncs.com/uPic/image-20240713183555890.png" alt="&#x73AF;&#x5883;&#x914D;&#x7F6E;&#x68C0;&#x6D4B;&#x7ED3;&#x679C;"></p>
<p>&#x901A;&#x8FC7;&#x4E0A;&#x9762;&#x7684;&#x68C0;&#x6D4B;&#x7ED3;&#x679C;&#x53EF;&#x4EE5;&#x770B;&#x5230;&#xFF0C;&#x6211;&#x4EEC;&#x7684;&#x73AF;&#x5883;&#x914D;&#x7F6E;&#x5DF2;&#x7ECF;&#x6210;&#x529F;&#xFF01;</p>
<h4 id="5-&#x73AF;&#x5883;&#x68C0;&#x6D4B;&#x7ED3;&#x679C;&#x793A;&#x4F8B;">5. &#x73AF;&#x5883;&#x68C0;&#x6D4B;&#x7ED3;&#x679C;&#x793A;&#x4F8B;</h4>
<pre><code class="lang-bash">jianguo@jianguodeMacBook-Pro-2 harmonyflutter % flutter doctor -v 
[&#x2713;] Flutter (Channel stable, 3.13.0, on macOS 13.4.1 22F82 darwin-arm64, locale zh-Hans-CN)
    &#x2022; Flutter version 3.13.0 on channel stable at /Users/jianguo/development/flutter
    &#x2022; Upstream repository https://github.com/flutter/flutter.git
    &#x2022; Framework revision efbf63d9c6 (11 &#x4E2A;&#x6708;&#x524D;), 2023-08-15 21:05:06 -0500
    &#x2022; Engine revision 1ac611c64e
    &#x2022; Dart version 3.1.0
    &#x2022; DevTools version 2.25.0
    &#x2022; Pub download mirror https://pub.flutter-io.cn
    &#x2022; Flutter download mirror https://storage.flutter-io.cn

[&#x2713;] Android toolchain - develop <span class="hljs-keyword">for</span> Android devices (Android SDK version 34.0.0)
    &#x2022; Android SDK at /Users/jianguo/Library/Android/sdk
    &#x2022; Platform android-34, build-tools 34.0.0
    &#x2022; ANDROID_HOME = /Users/jianguo/Library/Android/sdk
    &#x2022; Java binary at: /Applications/Android Studio.app/Contents/jbr/Contents/Home/bin/java
    &#x2022; Java version OpenJDK Runtime Environment (build 17.0.6+0-17.0.6b829.9-10027231)
    &#x2022; All Android licenses accepted.

[&#x2713;] Xcode - develop <span class="hljs-keyword">for</span> iOS and macOS (Xcode 14.3.1)
    &#x2022; Xcode at /Applications/Xcode.app/Contents/Developer
    &#x2022; Build 14E300c
    &#x2022; CocoaPods version 1.11.0

[&#x2713;] Chrome - develop <span class="hljs-keyword">for</span> the web
    &#x2022; Chrome at /Applications/Google Chrome.app/Contents/MacOS/Google Chrome

[&#x2713;] Android Studio (version 2022.3)
    &#x2022; Android Studio at /Applications/Android Studio.app/Contents
    &#x2022; Flutter plugin can be installed from:
      &#x1F528; https://plugins.jetbrains.com/plugin/9212-flutter
    &#x2022; Dart plugin can be installed from:
      &#x1F528; https://plugins.jetbrains.com/plugin/6351-dart
    &#x2022; Java version OpenJDK Runtime Environment (build 17.0.6+0-17.0.6b829.9-10027231)

[&#x2713;] VS Code (version 1.90.2)
    &#x2022; VS Code at /Applications/Visual Studio Code.app/Contents
    &#x2022; Flutter extension version 3.92.0

[&#x2713;] Connected device (2 available)
    &#x2022; macOS (desktop) &#x2022; macos  &#x2022; darwin-arm64   &#x2022; macOS 13.4.1 22F82 darwin-arm64
    &#x2022; Chrome (web)    &#x2022; chrome &#x2022; web-javascript &#x2022; Google Chrome 126.0.6478.127

[&#x2713;] Network resources
    &#x2022; All expected network resources are available.

&#x2022; No issues found!
</code></pre>
<blockquote>
<p>&#x2705; <strong>&#x6210;&#x529F;&#x6807;&#x5FD7;</strong>&#xFF1A;&#x770B;&#x5230;&quot;No issues found!&quot;&#x8868;&#x793A;&#x73AF;&#x5883;&#x914D;&#x7F6E;&#x5B8C;&#x5168;&#x6B63;&#x786E;&#xFF01;</p>
</blockquote>
<h2 id="&#x9879;&#x76EE;&#x521B;&#x5EFA;">&#x9879;&#x76EE;&#x521B;&#x5EFA;</h2>
<h3 id="&#x1F4C1;-&#x521B;&#x5EFA;&#x65B9;&#x5F0F;">&#x1F4C1; &#x521B;&#x5EFA;&#x65B9;&#x5F0F;</h3>
<p>Flutter&#x9879;&#x76EE;&#x521B;&#x5EFA;&#x6709;&#x4E24;&#x79CD;&#x65B9;&#x5F0F;&#xFF0C;&#x7F16;&#x8BD1;&#x4EA7;&#x7269;&#x4F4D;&#x4E8E;&#xFF1A;<code>${projectName}/ohos/entry/build/default/outputs/default/entry-default-signed.hap</code></p>
<h4 id="&#x65B9;&#x5F0F;&#x4E00;&#xFF1A;&#x4EC5;&#x521B;&#x5EFA;&#x9E3F;&#x8499;&#x5E73;&#x53F0;">&#x65B9;&#x5F0F;&#x4E00;&#xFF1A;&#x4EC5;&#x521B;&#x5EFA;&#x9E3F;&#x8499;&#x5E73;&#x53F0;</h4>
<pre><code class="lang-bash"><span class="hljs-comment"># &#x53EA;&#x521B;&#x5EFA;&#x9E3F;&#x8499;&#x5E73;&#x53F0;&#x9879;&#x76EE;</span>
flutter create --platforms ohos &lt;projectName&gt;
</code></pre>
<h4 id="&#x65B9;&#x5F0F;&#x4E8C;&#xFF1A;&#x521B;&#x5EFA;&#x591A;&#x5E73;&#x53F0;&#x9879;&#x76EE;">&#x65B9;&#x5F0F;&#x4E8C;&#xFF1A;&#x521B;&#x5EFA;&#x591A;&#x5E73;&#x53F0;&#x9879;&#x76EE;</h4>
<pre><code class="lang-bash"><span class="hljs-comment"># &#x521B;&#x5EFA;Android&#x3001;iOS&#x3001;&#x9E3F;&#x8499;&#x4E09;&#x4E2A;&#x5E73;&#x53F0;&#x9879;&#x76EE;</span>
flutter create &lt;projectName&gt;
</code></pre>
<h3 id="&#x1F680;-&#x521B;&#x5EFA;&#x793A;&#x4F8B;">&#x1F680; &#x521B;&#x5EFA;&#x793A;&#x4F8B;</h3>
<p>&#x8FD9;&#x91CC;&#x6211;&#x4EEC;&#x91C7;&#x7528;&#x7B2C;&#x4E00;&#x79CD;&#x65B9;&#x5F0F;&#xFF0C;&#x4EC5;&#x521B;&#x5EFA;&#x9E3F;&#x8499;&#x5E73;&#x53F0;&#x9879;&#x76EE;&#xFF1A;</p>
<pre><code class="lang-bash">flutter create --platforms ohos fluttertoharmony
</code></pre>
<h3 id="&#x2705;-&#x521B;&#x5EFA;&#x6210;&#x529F;">&#x2705; &#x521B;&#x5EFA;&#x6210;&#x529F;</h3>
<p>&#x5982;&#x4E0B;&#x56FE;&#x6240;&#x793A;&#xFF0C;&#x9879;&#x76EE;&#x521B;&#x5EFA;&#x6210;&#x529F;&#xFF1A;</p>
<p><img src="https://luckly007.oss-cn-beijing.aliyuncs.com/uPic/image-20240713172714711.png" alt="&#x9879;&#x76EE;&#x521B;&#x5EFA;&#x6210;&#x529F;"></p>
<pre><code>jianguo@jianguodeMacBook-Pro-2 teaching % flutter create --platforms ohos harmonyflutter
Creating project harmonyflutter...
Running &quot;flutter pub get&quot; in harmonyflutter...
Resolving dependencies in harmonyflutter... 
+ async 2.10.0 (2.11.0 available)
+ boolean_selector 2.1.1
+ characters 1.2.1 (1.3.0 available)
+ clock 1.1.1
+ collection 1.17.0 (1.19.0 available)
+ cupertino_icons 1.0.6 (1.0.8 available)
+ fake_async 1.3.1
+ flutter 0.0.0 from sdk flutter
+ flutter_lints 2.0.3 (4.0.0 available)
+ flutter_test 0.0.0 from sdk flutter
+ js 0.6.5 (0.7.1 available)
+ lints 2.0.1 (4.0.0 available)
+ matcher 0.12.13 (0.12.16+1 available)
+ material_color_utilities 0.2.0 (0.12.0 available)
+ meta 1.8.0 (1.15.0 available)
+ path 1.8.2 (1.9.0 available)
+ sky_engine 0.0.99 from sdk flutter
+ source_span 1.9.1 (1.10.0 available)
+ stack_trace 1.11.0 (1.11.1 available)
+ stream_channel 2.1.1 (2.1.2 available)
+ string_scanner 1.2.0 (1.3.0 available)
+ term_glyph 1.2.1
+ test_api 0.4.16 (0.7.3 available)
+ vector_math 2.1.4
Changed 24 dependencies in harmonyflutter!
Wrote 43 files.

All done!
You can find general documentation for Flutter at: https://docs.flutter.dev/
Detailed API documentation is available at: https://api.flutter.dev/
If you prefer video documentation, consider: https://www.youtube.com/c/flutterdev

In order to run your application, type:

  $ cd harmonyflutter
  $ flutter run

Your application code is in harmonyflutter/lib/main.dart.
</code></pre><blockquote>
<p>&#x1F389; <strong>&#x521B;&#x5EFA;&#x6210;&#x529F;</strong>&#xFF1A;&#x9879;&#x76EE;&#x5DF2;&#x6210;&#x529F;&#x521B;&#x5EFA;&#xFF0C;&#x5305;&#x542B;43&#x4E2A;&#x6587;&#x4EF6;&#xFF0C;24&#x4E2A;&#x4F9D;&#x8D56;&#x5305;&#x5DF2;&#x5B89;&#x88C5;&#x5B8C;&#x6210;&#xFF01;</p>
</blockquote>
<h2 id="&#x9879;&#x76EE;&#x7F16;&#x8BD1;&#x4E0E;&#x8FD0;&#x884C;">&#x9879;&#x76EE;&#x7F16;&#x8BD1;&#x4E0E;&#x8FD0;&#x884C;</h2>
<h3 id="&#x1F4F1;-&#x8BBE;&#x5907;&#x8FDE;&#x63A5;">&#x1F4F1; &#x8BBE;&#x5907;&#x8FDE;&#x63A5;</h3>
<p>&#x9996;&#x5148;&#x901A;&#x8FC7;<code>flutter devices</code>&#x6307;&#x4EE4;&#x53D1;&#x73B0;&#x771F;&#x673A;&#x8BBE;&#x5907;&#xFF0C;&#x83B7;&#x53D6;device-id&#xFF1A;</p>
<pre><code class="lang-bash">flutter devices
</code></pre>
<h3 id="&#x1F680;-&#x8FD0;&#x884C;&#x65B9;&#x5F0F;">&#x1F680; &#x8FD0;&#x884C;&#x65B9;&#x5F0F;</h3>
<h4 id="&#x65B9;&#x5F0F;&#x4E00;&#xFF1A;&#x76F4;&#x63A5;&#x8FD0;&#x884C;&#xFF08;&#x63A8;&#x8350;&#xFF09;">&#x65B9;&#x5F0F;&#x4E00;&#xFF1A;&#x76F4;&#x63A5;&#x8FD0;&#x884C;&#xFF08;&#x63A8;&#x8350;&#xFF09;</h4>
<p>&#x8FDB;&#x5165;&#x9879;&#x76EE;&#x76EE;&#x5F55;&#xFF0C;&#x6307;&#x5B9A;&#x6784;&#x5EFA;&#x65B9;&#x5F0F;&#x7F16;&#x8BD1;hap&#x5305;&#x5E76;&#x5B89;&#x88C5;&#x5230;&#x9E3F;&#x8499;&#x624B;&#x673A;&#x4E2D;&#xFF1A;</p>
<pre><code class="lang-bash">flutter run --debug --local-engine=/Users/jianguo/huawei/flutter_engine/src/out/ohos_debug_unopt_arm64 <span class="hljs-_">-d</span> &lt;deviceId&gt;
</code></pre>
<h4 id="&#x65B9;&#x5F0F;&#x4E8C;&#xFF1A;&#x5206;&#x6B65;&#x7F16;&#x8BD1;">&#x65B9;&#x5F0F;&#x4E8C;&#xFF1A;&#x5206;&#x6B65;&#x7F16;&#x8BD1;</h4>
<p>&#x8FDB;&#x5165;&#x5DE5;&#x7A0B;&#x6839;&#x76EE;&#x5F55;&#x7F16;&#x8BD1;hap&#x5305;&#xFF0C;&#x7136;&#x540E;&#x5B89;&#x88C5;&#x5230;&#x9E3F;&#x8499;&#x624B;&#x673A;&#x4E2D;&#xFF1A;</p>
<pre><code class="lang-bash"><span class="hljs-comment"># &#x7F16;&#x8BD1;HAP&#x5305;</span>
flutter build hap --local-engine=/Users/jianguo/huawei/flutter_engine/src/out/ohos_debug_unopt_arm64 --debug

<span class="hljs-comment"># &#x5B89;&#x88C5;&#x5230;&#x8BBE;&#x5907;</span>
hdc -t &lt;deviceId&gt; install &lt;hap file path&gt;
</code></pre>
<h4 id="&#x65B9;&#x5F0F;&#x4E09;&#xFF1A;&#x4F7F;&#x7528;deveco-studio">&#x65B9;&#x5F0F;&#x4E09;&#xFF1A;&#x4F7F;&#x7528;DevEco Studio</h4>
<p>&#x4F7F;&#x7528;DevEco Studio&#x9009;&#x62E9;&#x8BBE;&#x5907;&#x4E3A;&#x771F;&#x673A;&#xFF0C;&#x70B9;&#x51FB;&#x542F;&#x52A8;&#x6309;&#x94AE;&#x3002;</p>
<h3 id="&#x2705;-&#x8FD0;&#x884C;&#x6548;&#x679C;">&#x2705; &#x8FD0;&#x884C;&#x6548;&#x679C;</h3>
<p>&#x8FD0;&#x884C;&#x540E;&#x7684;&#x6548;&#x679C;&#x5982;&#x56FE;&#x6240;&#x793A;&#xFF1A;</p>
<p><img src="https://luckly007.oss-cn-beijing.aliyuncs.com/uPic/image-20240713175215412.png" alt="&#x5E94;&#x7528;&#x8FD0;&#x884C;&#x6548;&#x679C;"></p>
<h2 id="&#x9E3F;&#x8499;flutter&#x5F00;&#x53D1;&#x6A21;&#x5F0F;">&#x9E3F;&#x8499;Flutter&#x5F00;&#x53D1;&#x6A21;&#x5F0F;</h2>
<p>&#x5230;&#x76EE;&#x524D;&#x4E3A;&#x6B62;&#xFF0C;&#x9E3F;&#x8499;Flutter&#x5DE5;&#x7A0B;&#x5DF2;&#x7ECF;&#x521D;&#x5177;&#x96CF;&#x5F62;&#xFF0C;&#x6574;&#x4F53;&#x7684;&#x9002;&#x914D;&#x6548;&#x679C;&#x8FD8;&#x662F;&#x4E0D;&#x9519;&#x7684;&#x3002;&#x9E3F;&#x8499;Flutter&#x5F00;&#x53D1;&#x6709;&#x4E24;&#x79CD;&#x4E3B;&#x8981;&#x6A21;&#x5F0F;&#xFF1A;</p>
<h3 id="&#x1F3AF;-&#x5F00;&#x53D1;&#x6A21;&#x5F0F;&#x5BF9;&#x6BD4;">&#x1F3AF; &#x5F00;&#x53D1;&#x6A21;&#x5F0F;&#x5BF9;&#x6BD4;</h3>
<table>
<thead>
<tr>
<th>&#x6A21;&#x5F0F;</th>
<th>&#x63CF;&#x8FF0;</th>
<th>&#x4F18;&#x70B9;</th>
<th>&#x7F3A;&#x70B9;</th>
<th>&#x9002;&#x7528;&#x573A;&#x666F;</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>&#x7EAF;Flutter&#x5DE5;&#x7A0B;</strong></td>
<td>&#x9E3F;&#x8499;&#x4EE3;&#x7801;&#x5199;&#x5728;Flutter&#x5DE5;&#x7A0B;&#x4E2D;</td>
<td>&#x7B80;&#x5355;&#x6613;&#x7528;&#xFF0C;&#x5F00;&#x53D1;&#x6548;&#x7387;&#x9AD8;</td>
<td>&#x8026;&#x5408;&#x5EA6;&#x8F83;&#x9AD8;</td>
<td>&#x5FEB;&#x901F;&#x539F;&#x578B;&#x5F00;&#x53D1;</td>
</tr>
<tr>
<td><strong>&#x4EA7;&#x7269;&#x4F9D;&#x8D56;</strong></td>
<td>&#x901A;&#x8FC7;&#x4F9D;&#x8D56;&#x7F16;&#x8BD1;&#x4EA7;&#x7269;har&#x5F00;&#x53D1;</td>
<td>&#x89E3;&#x8026;&#x6027;&#x597D;&#xFF0C;&#x56E2;&#x961F;&#x534F;&#x4F5C;&#x53CB;&#x597D;</td>
<td>&#x914D;&#x7F6E;&#x590D;&#x6742;&#xFF0C;&#x9700;&#x8981;&#x9002;&#x914D;&#x4E09;&#x65B9;&#x5E93;</td>
<td>&#x5927;&#x578B;&#x9879;&#x76EE;&#xFF0C;&#x56E2;&#x961F;&#x5F00;&#x53D1;</td>
</tr>
</tbody>
</table>
<h3 id="&#x1F527;-&#x6280;&#x672F;&#x7279;&#x70B9;">&#x1F527; &#x6280;&#x672F;&#x7279;&#x70B9;</h3>
<h4 id="&#x6A21;&#x5F0F;&#x4E00;&#xFF1A;&#x7EAF;flutter&#x5DE5;&#x7A0B;">&#x6A21;&#x5F0F;&#x4E00;&#xFF1A;&#x7EAF;Flutter&#x5DE5;&#x7A0B;</h4>
<ul>
<li><strong>&#x6280;&#x672F;&#x4F18;&#x52BF;</strong>&#xFF1A;&#x9E3F;&#x8499;&#x7684;Native&#x4EE3;&#x7801;&#x5DF2;&#x7ECF;&#x662F;&#x58F0;&#x660E;&#x5F0F;&#x7684;&#xFF0C;&#x7C7B;&#x4F3C;Compose</li>
<li><strong>&#x4F7F;&#x7528;&#x7B80;&#x5355;</strong>&#xFF1A;&#x53EF;&#x4EE5;&#x76F4;&#x63A5;&#x5C06;<code>FlutterPage()</code>&#x5F53;&#x4F5C;&#x4E00;&#x4E2A;View&#x76F4;&#x63A5;&#x4F7F;&#x7528;</li>
<li><strong>&#x5F00;&#x53D1;&#x6548;&#x7387;</strong>&#xFF1A;&#x9E3F;&#x8499;Flutter&#x6DF7;&#x7F16;&#x6BD4;Android&#x3001;iOS&#x65B9;&#x4FBF;&#x5F88;&#x591A;</li>
</ul>
<h4 id="&#x6A21;&#x5F0F;&#x4E8C;&#xFF1A;&#x4EA7;&#x7269;&#x4F9D;&#x8D56;">&#x6A21;&#x5F0F;&#x4E8C;&#xFF1A;&#x4EA7;&#x7269;&#x4F9D;&#x8D56;</h4>
<ul>
<li><strong>&#x67B6;&#x6784;&#x4F18;&#x52BF;</strong>&#xFF1A;&#x66F4;&#x52A0;&#x7B26;&#x5408;&#x4E09;&#x7AEF;&#x7EDF;&#x4E00;&#x7684;&#x76EE;&#x6807;</li>
<li><strong>&#x56E2;&#x961F;&#x534F;&#x4F5C;</strong>&#xFF1A;&#x66F4;&#x9002;&#x5408;&#x56E2;&#x961F;&#x8FDB;&#x884C;&#x89E3;&#x8026;&#x548C;&#x534F;&#x4F5C;</li>
<li><strong>&#x6CE8;&#x610F;&#x4E8B;&#x9879;</strong>&#xFF1A;Flutter&#x4F9D;&#x8D56;&#x7684;&#x7B2C;&#x4E09;&#x65B9;&#x5E93;&#x9700;&#x8981;&#x9002;&#x914D;&#x9E3F;&#x8499;&#x7248;&#xFF0C;&#x5728;yaml&#x4E2D;&#x9700;&#x8981;&#x8FDB;&#x884C;&#x533A;&#x5206;</li>
</ul>
<h3 id="&#x1F4CB;-&#x4E09;&#x65B9;&#x5E93;&#x9002;&#x914D;&#x8BA1;&#x5212;">&#x1F4CB; &#x4E09;&#x65B9;&#x5E93;&#x9002;&#x914D;&#x8BA1;&#x5212;</h3>
<p>Flutter&#x7684;&#x4E09;&#x65B9;&#x5E93;&#x9002;&#x914D;&#x662F;&#x9E3F;&#x8499;&#x5F00;&#x53D1;&#x4E2D;&#x7684;&#x91CD;&#x8981;&#x73AF;&#x8282;&#xFF0C;&#x9700;&#x8981;&#x6839;&#x636E;&#x5177;&#x4F53;&#x5E93;&#x7684;&#x7279;&#x6027;&#x8FDB;&#x884C;&#x9002;&#x914D;&#x3002;</p>
<h2 id="&#x9E3F;&#x8499;flutter&#x5F00;&#x53D1;&#x6307;&#x4EE4;&#x5927;&#x5168;">&#x9E3F;&#x8499;Flutter&#x5F00;&#x53D1;&#x6307;&#x4EE4;&#x5927;&#x5168;</h2>
<h3 id="&#x1F4CB;-&#x5DF2;&#x517C;&#x5BB9;openharmony&#x5F00;&#x53D1;&#x7684;&#x6307;&#x4EE4;&#x5217;&#x8868;">&#x1F4CB; &#x5DF2;&#x517C;&#x5BB9;OpenHarmony&#x5F00;&#x53D1;&#x7684;&#x6307;&#x4EE4;&#x5217;&#x8868;</h3>
<table>
<thead>
<tr>
<th>&#x6307;&#x4EE4;&#x540D;&#x79F0;</th>
<th>&#x6307;&#x4EE4;&#x63CF;&#x8FF0;</th>
<th>&#x4F7F;&#x7528;&#x8BF4;&#x660E;</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>doctor</strong></td>
<td>&#x73AF;&#x5883;&#x68C0;&#x6D4B;</td>
<td><code>flutter doctor</code></td>
</tr>
<tr>
<td><strong>config</strong></td>
<td>&#x73AF;&#x5883;&#x914D;&#x7F6E;</td>
<td><code>flutter config --&lt;key&gt; &lt;value&gt;</code></td>
</tr>
<tr>
<td><strong>create</strong></td>
<td>&#x521B;&#x5EFA;&#x65B0;&#x9879;&#x76EE;</td>
<td><code>flutter create --platforms ohos,android,ios --org &lt;org&gt; &lt;appName&gt;</code></td>
</tr>
<tr>
<td><strong>create</strong></td>
<td>&#x521B;&#x5EFA;module&#x6A21;&#x677F;</td>
<td><code>flutter create -t module &lt;module_name&gt;</code></td>
</tr>
<tr>
<td><strong>create</strong></td>
<td>&#x521B;&#x5EFA;plugin&#x6A21;&#x677F;</td>
<td><code>flutter create -t plugin --platforms ohos,android,ios &lt;plugin_name&gt;</code></td>
</tr>
<tr>
<td><strong>create</strong></td>
<td>&#x521B;&#x5EFA;plugin_ffi&#x6A21;&#x677F;</td>
<td><code>flutter create -t plugin_ffi --platforms ohos,android,ios &lt;plugin_name&gt;</code></td>
</tr>
<tr>
<td><strong>devices</strong></td>
<td>&#x5DF2;&#x8FDE;&#x63A5;&#x8BBE;&#x5907;&#x67E5;&#x627E;</td>
<td><code>flutter devices</code></td>
</tr>
<tr>
<td><strong>install</strong></td>
<td>&#x5E94;&#x7528;&#x5B89;&#x88C5;</td>
<td><code>flutter install -t &lt;deviceId&gt; &lt;hap&#x6587;&#x4EF6;&#x8DEF;&#x5F84;&gt;</code></td>
</tr>
<tr>
<td><strong>assemble</strong></td>
<td>&#x8D44;&#x6E90;&#x6253;&#x5305;</td>
<td><code>flutter assemble</code></td>
</tr>
<tr>
<td><strong>build</strong></td>
<td>&#x6D4B;&#x8BD5;&#x5E94;&#x7528;&#x6784;&#x5EFA;</td>
<td><code>flutter build hap --debug [--target-platform ohos-arm64] [--local-engine=&lt;&#x517C;&#x5BB9;ohos&#x7684;debug engine&#x4EA7;&#x7269;&#x8DEF;&#x5F84;&gt;]</code></td>
</tr>
<tr>
<td><strong>build</strong></td>
<td>&#x6B63;&#x5F0F;&#x5E94;&#x7528;&#x6784;&#x5EFA;</td>
<td><code>flutter build hap --release [--target-platform ohos-arm64] [--local-engine=&lt;&#x517C;&#x5BB9;ohos&#x7684;release engine&#x4EA7;&#x7269;&#x8DEF;&#x5F84;&gt;]</code></td>
</tr>
<tr>
<td><strong>run</strong></td>
<td>&#x5E94;&#x7528;&#x8FD0;&#x884C;</td>
<td><code>flutter run [--local-engine=&lt;&#x517C;&#x5BB9;ohos&#x7684;engine&#x4EA7;&#x7269;&#x8DEF;&#x5F84;&gt;]</code></td>
</tr>
<tr>
<td><strong>attach</strong></td>
<td>&#x8C03;&#x8BD5;&#x6A21;&#x5F0F;</td>
<td><code>flutter attach</code></td>
</tr>
<tr>
<td><strong>screenshot</strong></td>
<td>&#x622A;&#x5C4F;</td>
<td><code>flutter screenshot</code></td>
</tr>
</tbody>
</table>
<h3 id="&#x1F3AF;-&#x5E38;&#x7528;&#x6307;&#x4EE4;&#x793A;&#x4F8B;">&#x1F3AF; &#x5E38;&#x7528;&#x6307;&#x4EE4;&#x793A;&#x4F8B;</h3>
<h4 id="&#x73AF;&#x5883;&#x68C0;&#x6D4B;">&#x73AF;&#x5883;&#x68C0;&#x6D4B;</h4>
<pre><code class="lang-bash"><span class="hljs-comment"># &#x68C0;&#x6D4B;&#x5F00;&#x53D1;&#x73AF;&#x5883;</span>
flutter doctor -v
</code></pre>
<h4 id="&#x9879;&#x76EE;&#x521B;&#x5EFA;">&#x9879;&#x76EE;&#x521B;&#x5EFA;</h4>
<pre><code class="lang-bash"><span class="hljs-comment"># &#x521B;&#x5EFA;&#x9E3F;&#x8499;&#x9879;&#x76EE;</span>
flutter create --platforms ohos my_app

<span class="hljs-comment"># &#x521B;&#x5EFA;&#x591A;&#x5E73;&#x53F0;&#x9879;&#x76EE;</span>
flutter create --platforms ohos,android,ios my_app
</code></pre>
<h4 id="&#x8BBE;&#x5907;&#x7BA1;&#x7406;">&#x8BBE;&#x5907;&#x7BA1;&#x7406;</h4>
<pre><code class="lang-bash"><span class="hljs-comment"># &#x67E5;&#x770B;&#x5DF2;&#x8FDE;&#x63A5;&#x8BBE;&#x5907;</span>
flutter devices

<span class="hljs-comment"># &#x5B89;&#x88C5;&#x5E94;&#x7528;&#x5230;&#x8BBE;&#x5907;</span>
flutter install -t &lt;deviceId&gt; app.hap
</code></pre>
<h4 id="&#x6784;&#x5EFA;&#x8FD0;&#x884C;">&#x6784;&#x5EFA;&#x8FD0;&#x884C;</h4>
<pre><code class="lang-bash"><span class="hljs-comment"># &#x8C03;&#x8BD5;&#x6784;&#x5EFA;</span>
flutter build hap --debug --local-engine=&lt;engine_path&gt;

<span class="hljs-comment"># &#x76F4;&#x63A5;&#x8FD0;&#x884C;</span>
flutter run --local-engine=&lt;engine_path&gt; <span class="hljs-_">-d</span> &lt;deviceId&gt;
</code></pre>
<h3 id="&#x1F4DA;-&#x603B;&#x7ED3;">&#x1F4DA; &#x603B;&#x7ED3;</h3>
<p>&#x901A;&#x8FC7;&#x672C;&#x7AE0;&#x7684;&#x5B66;&#x4E60;&#xFF0C;&#x6211;&#x4EEC;&#x4E86;&#x89E3;&#x4E86;&#xFF1A;</p>
<ol>
<li><strong>Flutter&#x57FA;&#x7840;&#x6982;&#x5FF5;</strong>&#xFF1A;&#x8DE8;&#x5E73;&#x53F0;UI&#x6846;&#x67B6;&#xFF0C;&#x4F7F;&#x7528;Dart&#x8BED;&#x8A00;&#x5F00;&#x53D1;</li>
<li><strong>&#x73AF;&#x5883;&#x642D;&#x5EFA;</strong>&#xFF1A;&#x9E3F;&#x8499;&#x7248;Flutter&#x7684;&#x5B8C;&#x6574;&#x73AF;&#x5883;&#x914D;&#x7F6E;&#x6D41;&#x7A0B;</li>
<li><strong>&#x9879;&#x76EE;&#x521B;&#x5EFA;</strong>&#xFF1A;&#x5982;&#x4F55;&#x521B;&#x5EFA;&#x9E3F;&#x8499;Flutter&#x9879;&#x76EE;</li>
<li><strong>&#x7F16;&#x8BD1;&#x8FD0;&#x884C;</strong>&#xFF1A;&#x591A;&#x79CD;&#x65B9;&#x5F0F;&#x7F16;&#x8BD1;&#x548C;&#x8FD0;&#x884C;&#x5E94;&#x7528;</li>
<li><strong>&#x5F00;&#x53D1;&#x6A21;&#x5F0F;</strong>&#xFF1A;&#x4E24;&#x79CD;&#x4E3B;&#x8981;&#x7684;&#x5F00;&#x53D1;&#x6A21;&#x5F0F;&#x53CA;&#x5176;&#x7279;&#x70B9;</li>
<li><strong>&#x5F00;&#x53D1;&#x6307;&#x4EE4;</strong>&#xFF1A;&#x5B8C;&#x6574;&#x7684;&#x9E3F;&#x8499;Flutter&#x5F00;&#x53D1;&#x6307;&#x4EE4;&#x96C6;</li>
</ol>
<blockquote>
<p>&#x1F389; <strong>&#x606D;&#x559C;</strong>&#xFF1A;&#x4F60;&#x5DF2;&#x7ECF;&#x5B8C;&#x6210;&#x4E86;&#x9E3F;&#x8499;Flutter&#x5F00;&#x53D1;&#x7684;&#x57FA;&#x7840;&#x5165;&#x95E8;&#xFF01;&#x63A5;&#x4E0B;&#x6765;&#x53EF;&#x4EE5;&#x5F00;&#x59CB;&#x5B9E;&#x9645;&#x7684;&#x5F00;&#x53D1;&#x5DE5;&#x4F5C;&#x4E86;&#x3002;</p>
</blockquote>
<footer class="page-footer"><span class="copyright">powered by Gitbook</span><span class="footer-modification">&#x8BE5;&#x6587;&#x4EF6;&#x4FEE;&#x8BA2;&#x65F6;&#x95F4;&#xFF1A;
2025-09-04 08:17:16
</span></footer>
<script>console.log("plugin-popup....");document.onclick = function(e){ e.target.tagName === "IMG" && window.open(e.target.src,e.target.src)}</script><style>img{cursor:pointer}</style> 
          </section>
          
    </div>
    <div class="search-results">
        <div class="has-results">
            
            <h1 class="search-results-title"><span class='search-results-count'></span> results matching "<span class='search-query'></span>"</h1>
            <ul class="search-results-list"></ul>
            
        </div>
        <div class="no-results">
            
            <h1 class="search-results-title">No results matching "<span class='search-query'></span>"</h1>
            
        </div>
    </div>
</div>
 
          <div class="book-footer">
            
            <div class="donate">
              <div></div>
              <button class="donate-btn" onclick="showModal()">赞赏</button>
            </div>
             
            <div class="copyright"></div>
            
          </div>
          
        </div>
      </div>
      
    </div>

     
    <a
      href="../chapter2/"
      class="navigation navigation-prev "
      aria-label="Previous page: 3.Flutter鸿蒙化"
    >
      <i class="fa fa-angle-left"></i>
    </a>
     
    <a
      href="02HarmonyOS与OpenHarmony介绍.html"
      class="navigation navigation-next "
      aria-label="Next page: 3.2 背景与原理"
    >
      <i class="fa fa-angle-right"></i>
    </a>
      
  </div>
  <script>
    function showModal() {
      document.getElementsByClassName("mask")[0].style.display = "block";
      document.getElementsByClassName("donate-modal")[0].style.display =
        "block";
    }
    // 切换赞赏码
    function showDonateImg(num) {
      let alipay = "";
      let wxpay = ""
      if(num){
        wxpay = "hidden"
      }else{
        alipay = "hidden"
      }
      document.getElementById("wxpay-code").hidden = wxpay;
      document.getElementById("alipay-code").hidden = alipay;
      document.getElementsByName("pay-way")[num].checked = "checked";
    }

    // 关闭赞赏框
    function closeDonateModal() {
      document.getElementsByClassName("mask")[0].style.display = "none";
      document.getElementsByClassName("donate-modal")[0].style.display = "none";
    }

    var gitbook = gitbook || [];
    gitbook.push(function () {
      gitbook.page.hasChanged({"page":{"title":"3.1 Flutter介绍","level":"1.3.1","depth":2,"next":{"title":"3.2 背景与原理","level":"1.3.2","depth":2,"path":"chapter1/02HarmonyOS与OpenHarmony介绍.md","ref":"./chapter1/02HarmonyOS与OpenHarmony介绍.md","articles":[]},"previous":{"title":"3.Flutter鸿蒙化","level":"1.3","depth":1,"path":"chapter2/README.md","ref":"chapter2/README.md","articles":[{"title":"3.1 Flutter介绍","level":"1.3.1","depth":2,"path":"chapter1/01Flutter介绍.md","ref":"./chapter1/01Flutter介绍.md","articles":[]},{"title":"3.2 背景与原理","level":"1.3.2","depth":2,"path":"chapter1/02HarmonyOS与OpenHarmony介绍.md","ref":"./chapter1/02HarmonyOS与OpenHarmony介绍.md","articles":[]},{"title":"3.3 功能开发","level":"1.3.3","depth":2,"path":"chapter1/02功能开发.md","ref":"./chapter1/02功能开发.md","articles":[]},{"title":"3.4 Flutter Engine编译","level":"1.3.4","depth":2,"path":"chapter1/03Flutter_Engine编译.md","ref":"./chapter1/03Flutter_Engine编译.md","articles":[]},{"title":"3.5 FutterEntry使用","level":"1.3.5","depth":2,"path":"chapter1/03FutterEntry使用.md","ref":"./chapter1/03FutterEntry使用.md","articles":[]},{"title":"3.6 性能调优","level":"1.3.6","depth":2,"path":"chapter1/04性能调优.md","ref":"./chapter1/04性能调优.md","articles":[]},{"title":"3.7 OHOS平台适配flutter三方库","level":"1.3.7","depth":2,"path":"chapter1/05OHOS平台适配flutter三方库.md","ref":"./chapter1/05OHOS平台适配flutter三方库.md","articles":[]},{"title":"3.8 如何使用Flutter Channel","level":"1.3.8","depth":2,"path":"chapter1/06如何使用_Flutter_Channel.md","ref":"./chapter1/06如何使用_Flutter_Channel.md","articles":[]},{"title":"3.9 开发Flutter静态库","level":"1.3.9","depth":2,"path":"chapter1/07开发Flutter静态库.md","ref":"./chapter1/07开发Flutter静态库.md","articles":[]},{"title":"3.10 FAQ","level":"1.3.10","depth":2,"path":"chapter1/FAQ.md","ref":"./chapter1/FAQ.md","articles":[]},{"title":"3.11 服务","level":"1.3.11","depth":2,"path":"chapter1/服务.md","ref":"./chapter1/服务.md","articles":[]},{"title":"3.12 资料整理","level":"1.3.12","depth":2,"path":"chapter1/资料整理.md","ref":"./chapter1/资料整理.md","articles":[]},{"title":"3.13 Impeller渲染引擎","level":"1.3.13","depth":2,"path":"chapter2/2.3Impeller渲染引擎.md","ref":"./chapter2/2.3Impeller渲染引擎.md","articles":[]}]},"dir":"ltr"},"config":{"plugins":["edit-link","splitter","tbfed-pagefooter","expandable-chapters","chapter-fold","back-to-top-button","code","pageview-count","popup","search-plus","-lunr","-search","-sharing","sharing-plus","theme-lou","emphasize","livereload","gitcode-issue-feedback","forkmegithub","livereload"],"root":".","styles":{"website":"styles/website.css"},"pluginsConfig":{"tbfed-pagefooter":{"modify_label":"该文件修订时间：","modify_format":"YYYY-MM-DD HH:mm:ss"},"chapter-fold":{},"pluginsConfig":{"expandable-chapters":{}},"emphasize":{},"livereload":{},"gitcode-issue-feedback":{"repo":"nutpi/gitbook-harmonyos-flutter"},"splitter":{},"readmore":{"blogId":"27976-1678928361372-483","name":"坚果派","qrcode":"https://luckly007.oss-cn-beijing.aliyuncs.com/images/image-20230316085818226.png","keyword":"鸿蒙坚果"},"sharing-plus":{"qq":false,"all":["facebook","google","twitter","instapaper","linkedin","pocket","stumbleupon"],"douban":false,"facebook":true,"weibo":false,"instapaper":false,"whatsapp":false,"hatenaBookmark":false,"twitter":true,"messenger":false,"line":false,"vk":false,"pocket":true,"google":false,"viber":false,"stumbleupon":false,"qzone":false,"linkedin":false},"popup":{},"code":{"copyButtons":true},"theme-lou":{"hide-elements":[".summary .gitbook-link",".summary .divider"],"color":"#FF4848","book-anchor-title":"本章目录","copyright":{"author":"vx:nut_pie"},"forbidCopy":true,"logo":"assets/avatar.png","book-summary-title":"文章目录","search-placeholder":"输入关键字搜索","copyrightLogo":"assets/copyright.png","favicon":"assets/avatar.png","appleTouchIconPrecomposed152":"assets/avatar.png"},"changyan":{"appid":"cyvHoCPAs","conf":"0440cfc4168ba95d73cfc52dd4d5c60b"},"fontsettings":{"theme":"white","family":"sans","size":2},"highlight":{},"back-to-top-button":{},"pageview-count":{},"sharing":{"qq":false,"all":["qq","qzone","whatsapp","douban","facebook","google","instapaper","linkedin","messenger","twitter","weibo"],"douban":false,"facebook":false,"weibo":false,"twitter":false,"pocket":false,"google":false,"qzone":false},"edit-link":{"label":"编辑此页","base":"https://gitcode.com/nutpi/gitbook-harmonyos-flutter/edit/master/"},"forkmegithub":{"color":"gray","url":"https://gitcode.com/nutpi/gitbook-harmonyos-flutter/fork/create"},"theme-default":{"styles":{"pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css","website":"styles/website.css"},"showLevel":false},"expandable-chapters":{},"search-plus":{}},"theme":"default","author":"坚果派","pdf":{"pageNumbers":true,"fontSize":12,"fontFamily":"Arial","paperSize":"a4","chapterMark":"pagebreak","pageBreaksBefore":"/","margin":{"right":62,"left":62,"top":56,"bottom":56}},"structure":{"langs":"LANGS.md","readme":"README.md","glossary":"GLOSSARY.md","summary":"SUMMARY.md"},"variables":{"themeLou":{"nav":[{"target":"_blank","url":"https://www.nutpi.net/","name":"坚果派官网"},{"target":"_blank","url":"https://www.arkui.club/","name":"ArkUI实战"},{"target":"_blank","url":"https://space.bilibili.com/480883651","name":"哔哩哔哩"},{"target":"_blank","url":"https://gitcode.com/nutpi","name":"GitCode"}],"footer":{"donate":{"wechat":"https://luckly007.oss-cn-beijing.aliyuncs.com/img/image-20210922202901895.png","message":"随意打赏，但不要超过一顿早餐钱 💕","wxpay":"https://luckly007.oss-cn-beijing.aliyuncs.com/img/image-20210922202901895.png","alipay":"https://luckly007.oss-cn-beijing.aliyuncs.com/img/image-20210922202843746.png","nickname":"breeze","button":"打赏","wechatText":"微信","alipayText":"支付宝","title":"『赠人玫瑰 🌹 手有余香 』","avatar":"http://xkapp-uat.oss-cn-hangzhou.aliyuncs.com/2e7a3f70-80ab-4b50-93ec-a04dfeef949b/avatar-100.png"},"copyright":true}}},"title":"Flutter for Harmony教程","language":"zh-hans","gitbook":"*","description":"Flutter for Harmony电子书教程"},"file":{"path":"chapter1/01Flutter介绍.md","mtime":"2025-09-04T00:17:16.188Z","type":"markdown"},"gitbook":{"version":"3.2.3","time":"2025-09-14T05:25:49.343Z"},"basePath":"..","book":{"language":""}});
    });
  </script>
</div>

        
    <script src="../gitbook/gitbook.js"></script>
    <script src="../gitbook/theme.js"></script>
    
        
        <script src="../gitbook/gitbook-plugin-edit-link/plugin.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-splitter/splitter.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-expandable-chapters/expandable-chapters.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-chapter-fold/chapter-fold.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-back-to-top-button/plugin.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-code/plugin.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-pageview-count/plugin.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-search-plus/jquery.mark.min.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-search-plus/search.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-sharing-plus/buttons.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-livereload/plugin.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-gitcode-issue-feedback/plugin.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-forkmegithub/plugin.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-fontsettings/fontsettings.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-theme-lou/jweixin-1.6.0.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-theme-lou/lou.js"></script>
        
    

    </body>
</html>

